Django基础之ORM初识

一.前言

今天我们大致来了解一下django的orm,只是简单的了解,具体的会在下一期和大家来说,本质是关系对象映射,简单点来说就是翻译,利用类创建数据库

二.表结构

2.1 基础配置

首先在app中的models.py中按照规则编写类

编写类

python 复制代码
from django.db import models

class UserInfo(models.Model):
    name = models.CharField(max_length=16)
    age = models.IntegerField()

注册app(这个前面都讲过了)

命令,django根据models中类生成一个 对数据库操作的配置文件 => migrations

python manage.py makemigrations

命令,读取已经注册么给app中的migrations目录将配置文件 -> 转换成:生成表,修改表 SQL -> 连接数据库去运行。

python manage.py migrate

  • 那个数据库?

  • 数据库账户和密码?

这节就不跟大家说如何去改配置了,通常我们都是配置mysql,这次我们就用他默认的

常见问题:请不要再手动去修改数据的表结构 + 时刻保证 ORM和数据表是对应。

2.2 常见字段和参数

字段

CharField //字符类型

SmallIntegerField //短整型

IntegerField //整形

BigIntegerField //长整型

DateField //日期

DateTimeField //日期和具体时间

BooleanField -> 其实数据库不支持真假,根据SmallIntegerField创造出来出来。 0 1

DecimalField -> 精确的小数

复制代码
name=models.CharField(max_length=16,verbose_name='姓名')
age=models.IntegerField(verbose_name='年龄')

参数

通用参数

verbose_name="姓名" :用来知道这个字段的含义

default :默认值

null=True:通常和blank一起写,允许数据库值为空

blank=True:允许页面展示为空

db_index=True:建立索引

choices=(("sh", "上海"), ("bj", "北京")) :采用元组套着元组,表示值只能元组里面选,里面的元组前面是数据库存储,后面是页面的展示

unique=True :唯一值,不允许重复

字符类型

max_length 一定要加上,约束最大长度

code = models.CharField(verbose_name="姓名", max_length=16, choices=(("sh", "上海"), ("bj", "北京")),default="sh")

整数类型

无特殊参数

count = models.IntegerField(verbose_name="数量", default=1, null=True, blank=True, unique=True)

时间类型

auto_now=True :添加值的时候自动把当前时间添加进去,就可以不用手动传

register_date = models.DateField(verbose_name="注册时间", auto_now=True)

精准小数类型

max_digits=10 :最大长度是10

decimal_places=2 :小数点后面保留两位

示例:

python 复制代码
from django.db import models

class UserInfo(models.Model):
    name = models.CharField(verbose_name="姓名", max_length=16, db_index=True)
    age = models.PositiveIntegerField(verbose_name="年龄")
    email = models.CharField(verbose_name="邮箱", max_length=128, unique=True)
    amount = models.DecimalField(verbose_name="余额", max_digits=10, decimal_places=2, default=0)
    register_date = models.DateField(verbose_name="注册时间", auto_now=True)


class Goods(models.Model):
    title = models.CharField(verbose_name="标题", max_length=32)
    # detail = models.CharField(verbose_name="详细信息", max_length=255)
    detail = models.TextField(verbose_name="详细信息")
    price = models.PositiveIntegerField(verbose_name="价格")
    count = models.PositiveBigIntegerField(verbose_name="库存", default=0)

2.3 表关系

一对多关系:

有的时候我们会有一对多的关系,比如上图,一个部门会有多个用户,那此时此刻我们就要创建表关系了

python 复制代码
from django.db import models

class Department(models.Model):
    '''部门表'''
    title=models.CharField(verbose_name='部门标题',max_length=16)


class UserInfo(models.Model):
    '''用户表'''
    name=models.CharField(verbose_name='姓名',max_length=16)
    # to_fields如果不写就是默认关联id字段 models.CASCADE就是级联删除
    depart=models.ForeignKey(verbose_name='部门ID',to='Department',to_field='id',on_delete=models.CASCADE)

    # models.SET_NULL 删除就设置为空
    # depart=models.ForeignKey(verbose_name='部门ID',to='Department',to_field='id',on_delete=models.SET_NULL,null=True,blank=True)
    
    # models.SET_DEFAULT 删除就设置成默认值
    # depart=models.ForeignKey(verbose_name='部门ID',to='Department',to_field='id',on_delete=models.SET_DEFAULT,default=1)

多对多关系:

如图这个就是一个多对多关系,男生可以和任意的女生约会,女生也可以和任意的男生约会,但是如果我们在男女后面都加上一个约会的男女字段,那么就会出现大量的冗余,此时此刻我们就需要创建第三张表,表中对应上男女的字段, 专门存储男女的约会信息

python 复制代码
from django.db import models
class Boy(models.Model):
    name=models.CharField(verbose_name='姓名',max_length=16)

class Girl(models.Model):
    name=models.CharField(verbose_name='姓名',max_length=16)

class B2G(models.Model):
    bid=models.ForeignKey(verbose_name='男生ID',to='Boy',to_field='id',on_delete=models.CASCADE)
    gid=models.ForeignKey(verbose_name='女生ID',to='Girl',to_field='id',on_delete=models.CASCADE)

或者使用ManytoManyField字段自动生成第三张表,但是这个表只能对应上两个字段的对应关系,无法再加上其他数据,例如约会地点啥啥啥的

python 复制代码
from django.db import models
class Boy(models.Model):
    name=models.CharField(verbose_name='姓名',max_length=16)
    
class Girl(models.Model):
    name=models.CharField(verbose_name='姓名',max_length=16)
    relation=models.ManyToManyField(verbose_name='男女关系',to='Boy')

三.总结

今天主要还是简单知识点,做个了解就行了,下次会和大家具体讲orm,那个篇幅就很长了,本章相当于是药引,下一期才是猛药

四.补充

下一期将和具体讲解一下orm,期待大家的点赞关注加收藏

相关推荐
Java知识技术分享30 分钟前
使用LangChain构建第一个ReAct Agent
python·react.js·ai·语言模型·langchain
奔跑吧邓邓子40 分钟前
【Python爬虫(44)】分布式爬虫:筑牢安全防线,守护数据之旅
开发语言·分布式·爬虫·python·安全
程序员 小濠1 小时前
接口测试基础 --- 什么是接口测试及其测试流程?
自动化测试·python·测试工具·职场和发展·appium·接口测试·压力测试
程序媛徐师姐1 小时前
Python基于Django的酒店推荐系统【附源码】
python·django·酒店·酒店推荐·python django·酒店推荐系统·python酒店推荐系统
大脑经常闹风暴@小猿2 小时前
1.1 go环境搭建及基本使用
开发语言·后端·golang
尚学教辅学习资料2 小时前
基于SpringBoot的美食分享平台+LW示例参考
spring boot·后端·美食
~kiss~2 小时前
python的thrift2pyi学习
windows·python·学习
奔跑吧邓邓子2 小时前
【Python爬虫(45)】Python爬虫新境界:分布式与大数据框架的融合之旅
开发语言·分布式·爬虫·python·大数据框架
Luke Ewin2 小时前
根据音频中的不同讲述人声音进行分离音频 | 基于ai的说话人声音分离项目
人工智能·python·音视频·语音识别·声纹识别·asr·3d-speaker
大米洗澡2 小时前
数字签名技术基础
python·学习·程序人生·面试·职场和发展