Django ORM学习

本文介绍了Django中如何使用ORM(对象关系映射)框架进行数据库操作,包括配置数据库信息、定义模型类、创建迁移文件及执行迁移,以及模型字段类型和约束的详细说明。通过模型类实现对数据库表的增删改查,简化了传统SQL语句的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Django中内嵌了ORM框架,不需要直接编写SQL语句进行数据库操作,而是通过定义模型
O-object,类对象

R-relation,数据表

M-mapping,映射。类,操作模型类来完成对数据库中表的增删改查和创建等操作。
映射关系:

类:sql语句table表
类成员变量:table表中的字段、类型和约束
类对象:sql表的表记录

操作数据库的步骤

  1. 在setting里面配置数据库信息
  2. 在models.py里面定义模型类
  3. 生成数据库迁移文件并执行迁移文件
  4. 通过模型类对象提供的方法或属性完成数据表的增删改查操作

配置数据库信息(以mysql为例子)

  • 安装pymysql
    pip install PyMySQL
  • 在Django的工程同名子目录的__init__.py文件中添加如下语句-
 from pymysql import install_as_MySQLdb
 install_as_MySQLdb()
  • 配置数据库
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'HOST': '127.0.0.1',  # 数据库主机
        'PORT': 3306,  # 数据库端口
        'USER': 'root',  # 数据库用户名
        'PASSWORD': 'root',  # 数据库用户密码
        'NAME': 'databasename'  # 数据库名字
    }
}

定义模型类

在models.py下书写模型类,继承于模型类

from django.db import models

# Create your models here.
class myModel(models.Model):
    # 属性名 = models.字段类型(约束选项, verbose_name="注释")
    name = models.CharField(max_length=16)
    age = models.SmallIntegerField(null= True)
    
字段类型
类型说明
AutoField自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性
BooleanField布尔字段,值为True或False
NullBooleanField支持Null、True、False三种值
CharField字符串,参数max_length表示最大字符个数,对应mysql中的varchar
TextField大文本字段,一般大段文本(超过4000个字符)才使用。
IntegerField整数
DecimalField十进制浮点数, 参数max_digits表示总位数, 参数decimal_places表示小数位数,常用于表示分数和价格 Decimal(max_digits=7, decimal_places=2) ==> 99999.99~ 0.00
FloatField浮点数
DateField日期
参数auto_now表示每次保存对象时,自动设置该字段为当前时间。
参数auto_now_add表示当对象第一次被创建时自动设置当前。
参数auto_now_add和auto_now是相互排斥的,一起使用会发生错误。
TimeField时间,参数同DateField
DateTimeField日期时间,参数同DateField
FileField上传文件字段,django在文件字段中内置了文件上传保存类, django可以通过模型的字段存储自动保存上传文件, 但是, 在数据库中本质上保存的仅仅是文件在项目中的存储路径!!
ImageField继承于FileField,对上传的内容进行校验,确保是有效的图片
约束选项
选项说明
null如果为True,表示允许为空,默认值是False。相当于python的None
blank如果为True,则该字段允许为空白,默认值是False。 相当于python的空字符串,“”
db_column字段的名称,如果未指定,则使用属性的名称。
db_index若值为True, 则在表中会为此字段创建索引,默认值是False。 相当于SQL语句中的key
default默认值,当不填写数据时,使用该选项的值作为数据的默认值。
primary_key如果为True,则该字段会成为模型的主键,默认值是False,一般不用设置,系统默认设置。
unique如果为True,则该字段在表中必须有唯一值,默认值是False。相当于SQL语句中的unique

生成数据库迁移文件并且执行

python manage.py makemigrations
python manage.py migrate
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值