
模型设计
- 当前项目开发,都是数据驱动的,及分析出项目中所需要存储的数据然后设计数据表及结构接下来再使用设计好的页面对表完成数据的crud
- django 中内嵌了ORM框架,不需要直接面向数据库编程,而是定义模型类,通过模型类和对象完成数据表的crud
- 使用django进行数据库开发的步骤如下:
- 在models.py 中定义模型类
- 迁移
3.通过类和对象完成数据crud
1.定义模型类
- 模型类定义在models.py文件中,继承自models.Model类
- 说明:不需要定义主键列,在生成会自动添加,并且为自动增长
- 图书表结构设计:
- 图书表结构设计:
- 表名:BookInfo
- 图书名称: btitle
- 图书发布日期:bpub_date
- 表名:HeroInfo
- 英雄姓名:hname
- 英雄性别:hgender
- 英雄简介:hcontent
- 所属图书:hbook
- 图书-英雄的关系为一对多
- 根据设计,在models.py 中定义模型类如下:

2.迁移

- 生成迁移文件:根据模型类生成创建表的语句
- 执行迁移:根据第一步生成的语句在数据库中创建表
python manage.py makemigrations




3.数据操作
- 进入项目的shell ,进行简单的API操作
- 按ctrl+d或输入quit()可以退出shell
python manage.py shell

from booktest.models import BookInfo,HeroInfo
BookInfo.objects.all()

b=BookInfo()
b.btitle="射雕英雄传"
from datetime import date
b.bpub_date=date(1990,1,10)
b.save()

b=BookInfo.objects.get(pk=1)
b
b.id
b.btitle
b.bpub_date

b.bpub_date=date(2017,1,1)
b.save()
b.bpub_date

b.bpub_date=date(2017,1,1)
b.save()
b.bpub_date

对象的关联操作
- 对于HeroInfo可以按照上面的方式进行ctud操作
- 创建一个BookInfo对象
b=BookInfo()
b.btitle='abc'
b.bpub_date=date(2017,1,1)
b.save()
h=HeroInfo()
h.htitle='a1'
h.hgender=True
h.hcontent='he is a boy'
h.hBook=b
h.save()
- 图书与英雄是一对多的关系。Django中提供了关联的操作方式
- 获取关联集合:返回当前book对象的所有hero
b.heroinfo_set.all()
