Django中的模板层

模型层

Django下配置使用 mysql 数据库

  1. 安装 mysqlclient [版本 mysqlclient 1.3.13以上 ,官网目前为1.4.x]
    • 安装前确认ubuntu是否已安装 python3-dev 和 default-libmysqlclient-dev

    • sudo apt list --installed|grep -E ‘libmysqlclient-dev|python3-dev’

  • 若命令无输出则需要安装 - sudo apt-get install python3-dev default-libmysqlclient-dev

    • 确保上述两个库已经安装,执行 sudo pip3 install mysqlclient即可
  1. 创建 和 配置数据库

    1. 创建数据库

      • 创建 create database 数据库名 default charset utf8 ;
      create database mywebdb default charset utf8 collate utf8_general_ci;
      
    2. 数据库的配置

      • sqlite 数据库配置

        # file: settings.py
        DATABASES = {
            'default': {
                    'ENGINE': 'django.db.backends.sqlite3',
                    'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
            }
        }
        
      • mysql 数据库配置

        DATABASES = {
            'default' : {
                'ENGINE': 'django.db.backends.mysql',
                'NAME': 'mywebdb',  # 数据库名称,需要自己定义
                'USER': 'root',
                'PASSWORD': '123456',  # 管理员密码
                'HOST': '127.0.0.1',
                'PORT': 3306,
            }
        }
        
    3. 关于数据为的SETTING设置

      1. ENGINE

        • 指定数据库的后端引擎
        'django.db.backends.mysql'
        'django.db.backends.sqlite3'
        'django.db.backends.oracle'
        'django.db.backends.postgresql'
        
        • mysql引擎如下:
          • ‘django.db.backends.mysql’
      2. NAME

        • 指定要连接的数据库的名称
        • 'NAME': 'mywebdb'
      3. USER

        • 指定登录到数据库的用户名
        • 'USER':'root'
      4. PASSWORD

        • 接数据库的密码。
        • 'PASSWORD':'123456'
      5. HOST

        • 连接数据库时使用哪个主机。
        • 'HOST':'127.0.0.1'
      6. PORT

        • 连接数据库时使用的端口。
        • 'PORT':'3306'

模型(Models)

  • 模型是一个Python类,它是由django.db.models.Model派生出的子类。
  • 一个模型类代表数据库中的一张数据表
  • 模型类中每一个类属性都代表数据库中的一个字段。
  • 模型是数据交互的接口,是表示和操作数据库的方法和方式

Django 的 ORM框架

  • ORM(Object Relational Mapping)即对象关系映射,它是一种程序技术,它允许你使用类和对象对数据库进行操作,从而避免通过SQL语句操作数据库
  • ORM框架的作用
    1. 建立模型类和表之间的对应关系,允许我们通过面向对象的方式来操作数据库。
    2. 根据设计的模型类生成数据库中的表格。
    3. 通过简单的配置就可以进行数据库的切换。
  • ORM 好处:
    1. 只需要面向对象编程, 不需要面向数据库编写代码.
      • 对数据库的操作都转化成对类属性和方法的操作.
      • 不用编写各种数据库的sql语句.
    2. 实现了数据模型与数据库的解耦, 屏蔽了不同数据库操作上的差异.
      • 不在关注用的是mysql、oracle…等数据库的内部细节.
      • 通过简单的配置就可以轻松更换数据库, 而不需要修改代码.
  • ORM 缺点
    1. 对于复杂业务,使用成本较高
    2. 根据对象的操作转换成SQL语句,根据查询的结果转化成对象, 在映射过程中有性能损失.
  • ORM 示意
    • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SNJq3o4O-1655020576132)(/home/tarena/下载/Django_Note/day03/images/orm.png)]

模型示例

  • 此示例为添加一个 bookstore_book 数据表来存放图书馆中书目信息

  • 添加一个 bookstore 的 app

    $ python3 manage.py startapp bookstore
    
  • 注册app

    # file : setting.py
    INSTALLED_APPS = [
        ...
        'bookstore',
    ]
    
  • 添加模型类

    # file : bookstore/models.py
    from django.db import models
    
    class Book(models.Model): 
        title = models.CharField("书名", max_length=50, default='')
        price = models.DecimalField('定价', max_digits=7, decimal_places=2, default=0.0)
    
  • 数据库的迁移

    • 迁移是Django同步您对模型所做更改(添加字段,删除模型等) 到您的数据库模式的方式
    1. 生成或更新迁移文件

    ​ 将每个应用下的models.py文件生成一个中间文件,并保存在migrations文件夹中

    python3 manage.py makemigrations

    1. 执行迁移脚本程序

      执行迁移程序实现迁移。将每个应用下的migrations目录中的中间文件同步回数据库

      python3 manage.py migrate

      注: 每次修改完模型类再对服务程序运行之前都需要做以上两步迁移操作。

模型类Models 创建

  • 模型类需继承自django.db.models.Model

    Models的语法规范

    from django.db import models
    class 模型类名(models.Model):
        字段名 = models.字段类型(字段选项)
    

    模型类名是数据表名的一部分,建议类名首字母大写
    字段名又是当前类的类属性名,此名称将作为数据表的字段名
    字段类型用来映射到数据表中的字段的类型
    字段选项为这些字段提供附加的参数信息

字段类型
  1. BooleanField()

    • 数据库类型:tinyint(1)
    • 编程语言中:使用True或False来表示值
    • 在数据库中:使用1或0来表示具体的值
  2. CharField()

    • 数据库类型:varchar
    • 注意:
      • 必须要指定max_length参数值
  3. DateField()

    • 数据库类型:date
    • 作用:表示日期
    • 参数:
      • auto_now: 每次保存对象时,自动设置该字段为当前时间(取值:True/False)。
      • auto_now_add: 当对象第一次被创建时自动设置当前时间(取值:True/False)。
      • default: 设置当前时间(取值:字符串格式时间如: ‘2019-6-1’)。
      • 以上三个参数只能多选一
  4. DateTimeField()

    • 数据库类型:datetime(6)
    • 作用:表示日期和时间
    • 参数同DateField
  5. DecimalField()

    • 数据库类型:decimal(x,y)

    • 编程语言中:使用小数表示该列的值

    • 在数据库中:使用小数

    • 参数:

      • max_digits: 位数总数,包括小数点后的位数。 该值必须大于等于decimal_places.
      • decimal_places: 小数点后的数字数量
    • 示例:

      money=models.DecimalField(
          max_digits=7,
          decimal_places=2,
          default=0.0
      )
      
  6. FloatField()

    • 数据库类型:double
    • 编程语言中和数据库中都使用小数表示值
  7. EmailField()

    • 数据库类型:varchar
    • 编程语言和数据库中使用字符串
  8. IntegerField()

    • 数据库类型:int
    • 编程语言和数据库中使用整数
  9. URLField()

    • 数据库类型:varchar(200)
    • 编程语言和数据库中使用字符串
  10. ImageField()

    • 数据库类型:varchar(100)
    • 作用:在数据库中为了保存图片的路径
    • 编程语言和数据库中使用字符串
  11. TextField()

    • 数据库类型:longtext
    • 作用:表示不定长的字符数据
字段选项
  • 字段选项, 指定创建的列的额外的信息
  • 允许出现多个字段选项,多个选项之间使用,隔开
  1. primary_key
    • 如果设置为True,表示该列为主键,如果指定一个字段为主键,则此数库表不会创建id字段
  2. blank
    • 设置为True时,字段可以为空。设置为False时,字段是必须填写的。
  3. null
    • 如果设置为True,表示该列值允许为空。
    • 默认为False,如果此选项为False建议加入default选项来设置默认值
  4. default
    • 设置所在列的默认值,如果字段选项null=False建议添加此项
  5. db_index
    • 如果设置为True,表示为该列增加索引
  6. unique
    • 如果设置为True,表示该字段在数据库中的值必须是唯一(不能重复出现的)
  7. db_column
    • 指定列的名称,如果不指定的话则采用属性名作为列名
  8. verbose_name
    • 设置此字段在admin界面上的显示名称。
Meta内部类
  • 使用内部 Meta类 来给模型赋予属性,Meta类下有很多内建的类属性,可对模型类做一些控制

  • 示例:

    # file : bookstore/models.py
    from django.db import models
    
    class Book(models.Model): 
        title = models.CharField("书名", max_length=50, default='')
        price = models.DecimalField('定价', max_digits=7, decimal_places=2, default=0.0)
        class Meta:
            db_table = 'book'  #可改变当前模型类对应的表名
    

数据库迁移的错误处理方法

  • 当执行 $ python3 manage.py makemigrations 出现如下迁移错误时的处理方法

    • 错误信息

      You are trying to add a non-nullable field 'des' to book without a default; we can't do that (the database needs something to populate existing rows).
      Please select a fix:
       1) Provide a one-off default now (will be set on all existing rows with a null value for this column)
       2) Quit, and let me add a default in models.py
      Select an option:  
      
    • 翻译为中文如下:

      您试图添加一个非空字段'des'来预订没有默认;我们不能这样做(数据库需要填充现有行)
      请选择修复:
      1)现在提供一次性默认值(将对所有现有行设置此列的空值)
      2)退出,让我在models.py中添加一个默认值
      选择一个选项:
      
    • 错误原因

      • 当对模型类新添加一个字段时可出现该错误
      • 原理是 添加新字段后,数据库不知道原来已有数据对于新建字段该如何赋值,所以新增字段时,务必要添加default默认值。
    • 处理方法:

      1. 选择1 则会进入到shell中,手动输入一个默认值
      2. 退出当前生成迁移文件的过程,自己去修改models.py, 新增加一个default=XXX 的缺省值(推荐使用)
  • 数据库的迁移文件混乱的解决办法

    1. 删除 所有 migrations 里所有的 000?_XXXX.py (__init__.py除外)
    2. 删除 数据库
      • sql> drop database mywebdb;
    3. 重新创建 数据库
      • sql> create datebase mywebdb default charset…;
    4. 重新生成migrations里所有的 000?_XXXX.py
      • python3 manage.py makemigrations
    5. 重新更新数据库
      • python3 manage.py migrate
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Fan Wang&YuanyuanLuo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值