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,期待大家的点赞关注加收藏

相关推荐
面向Google编程3 小时前
从零学习Kafka:数据存储
后端·kafka
冷雨夜中漫步3 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
郝学胜-神的一滴3 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
百锦再3 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
易安说AI3 小时前
Claude Opus 4.6 凌晨发布,我体验了一整晚,说说真实感受。
后端
易安说AI3 小时前
Ralph Loop 让Claude无止尽干活的牛马...
前端·后端
易安说AI4 小时前
用 Claude Code 远程分析生产日志,追踪 Claude Max 账户被封原因
后端
颜酱5 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
喵手5 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
2501_944934735 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python