Bootstrap

Django基础之ORM初识

一.前言

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

二.表结构

2.1 基础配置

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

编写类

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  :小数点后面保留两位

示例: 

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 表关系 

一对多关系:

 

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

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)

多对多关系:

 

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

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字段自动生成第三张表,但是这个表只能对应上两个字段的对应关系,无法再加上其他数据,例如约会地点啥啥啥的

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

 

;