自学python 进击之路 - Django-入门(设计模型)

122 阅读2分钟

src=http___5b0988e595225.cdn.sohucs.com_images_20190916_32ce26032b124c3cb145a4231627373d.jpeg&refer=http___5b0988e595225.cdn.sohucs.jpg

模型设计

  • 当前项目开发,都是数据驱动的,及分析出项目中所需要存储的数据然后设计数据表及结构接下来再使用设计好的页面对表完成数据的crud
  • django 中内嵌了ORM框架,不需要直接面向数据库编程,而是定义模型类,通过模型类和对象完成数据表的crud
  • 使用django进行数据库开发的步骤如下:
  1. 在models.py 中定义模型类
  2. 迁移 3.通过类和对象完成数据crud

1.定义模型类

  • 模型类定义在models.py文件中,继承自models.Model类
  • 说明:不需要定义主键列,在生成会自动添加,并且为自动增长
  • 图书表结构设计:
  • 图书表结构设计:
  1. 表名:BookInfo
  2. 图书名称: btitle
  3. 图书发布日期:bpub_date
  • 英雄表结构设计:
  1. 表名:HeroInfo
  2. 英雄姓名:hname
  3. 英雄性别:hgender
  4. 英雄简介:hcontent
  5. 所属图书:hbook
  • 图书-英雄的关系为一对多
  • 根据设计,在models.py 中定义模型类如下:

Snipaste_2021-06-19_13-15-37.png

2.迁移

  • 默认采用sqlite3数据库
  • 迁移前目录结构

Snipaste_2021-06-19_13-18-51.png

  • 迁移由两步完成
  1. 生成迁移文件:根据模型类生成创建表的语句
  2. 执行迁移:根据第一步生成的语句在数据库中创建表
  • 生成迁移文件命令
python manage.py makemigrations

Snipaste_2021-06-19_13-22-08.png

  • 执行迁移命令如下:

Snipaste_2021-06-19_13-23-20.png

  • 迁移后目录结构:

Snipaste_2021-06-19_13-26-23.png

Snipaste_2021-06-19_13-27-31.png

3.数据操作

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

Snipaste_2021-06-19_13-30-44.png

  • 首先引入booktest/models 中的类
from booktest.models import BookInfo,HeroInfo
  • 查看所有图书信息
BookInfo.objects.all()
  • 因为当前并没有数据,所以返回空列表

Snipaste_2021-06-19_13-37-02.png

  • 新建图书对象
b=BookInfo()
b.btitle="射雕英雄传"
from datetime import date
b.bpub_date=date(1990,1,10)
b.save()

Snipaste_2021-06-19_14-48-31.png

  • 再次查询所有图书
b=BookInfo.objects.get(pk=1)
b
b.id
b.btitle
b.bpub_date

Snipaste_2021-06-19_14-51-16.png

  • 修改图书信息
b.bpub_date=date(2017,1,1)
b.save()
b.bpub_date

Snipaste_2021-06-19_14-52-49.png

  • 删除图书信息
b.bpub_date=date(2017,1,1)
b.save()
b.bpub_date

Snipaste_2021-06-19_14-54-56.png

对象的关联操作

  • 对于HeroInfo可以按照上面的方式进行ctud操作
  • 创建一个BookInfo对象
b=BookInfo()
b.btitle='abc'
b.bpub_date=date(2017,1,1)
b.save()
  • 创建一个HeroInfo对象
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()

Snipaste_2021-06-19_15-04-46.png