day4-Django的model

这篇具有很好参考价值的文章主要介绍了day4-Django的model。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1)setting文件配置

2)理解models

3)model定义

4)常用字段类型

5)常用属性

6)数据库迁移

7)Meta类


1)setting文件配置

sqlite数据库:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',
    }
}

mysql数据库:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'bbs', # 数据库名称
        'USER': 'root',
        'PASSWORD': 'root',
        'HOST': '127.0.0.1',
        'PORT': '3306',
    }
​
}

2)理解models

所有的Model都必须继承自django.db.models.Model,可以是直接继承或者间接继承,所有字段都是 djaogo.db.models.Field的子类,Django会根据field的类型确定数据库中表字段的类型

3)model定义

from django.db import models
from ckeditor_uploader.fields import RichTextUploadingField
# Create your models here.
from user.models import User
​
​
class Article(models.Model):
    title = models.CharField('标题', max_length=20)
    # 发行时间
    pub_time = models.DateTimeField('发表时间',
                                    auto_now_add=True)
    # 内容
    content = RichTextUploadingField(verbose_name="内容",blank=False,null=False)
    # 用户id
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    class Meta:
        db_table = 'article'  # 修改表名

4)常用字段类型

每个字段都是 django.db.models.fields.Field的实例

字段名 描述 举例
CharField 字符串类型
TextField 文本类型
EmailField 邮箱类型
UrlField 网址类型
BooleanField 布尔类型
IntegerField 整型
DecimalField 浮点类型
FloatFie1d 十进制小数类型
DateField 日期类型 xxxx-xx-xx
DateTimeField 日期类型 xxxx-xx-xx xx:xx:xx
TimeField 时间类型 xx:xx:xx
ImageField 图片类型 xxx.jpg
FileField 文件类型 任意文件
ForeignKey 多对一 相当于外键
OneToOneField 一对一 用于拓展模型
ManyToManyField 多对多

5)常用属性

特殊属性

字段名 描述 作用于
max_digits 数字中的最大位数 DecimalField
decimal_places 存储的十进制位数 DecimalField
height_field width_field 图片的宽和高 ImageField
upload_to 保存上传文件的本地路径 FileField ImageField
related_name 多对一和多对多字段反向引用的字段名

公共属性

字段名 描述 作用于
null 是否可设为空
blank 是否设为空
primary_key 设置主键 IntegerField
auto_now 时间自动添加 TimeField
auto_now_add 时间自动添加,仅仅在创建的时候 TimeField
max_length 字段长度,sqlite数据库不生效 CharField
default 默认值
verbose_name admin显示的名字
db_column 数据库字段名
unique 唯一索引
db_index 普通索引

6)数据库迁移

对模型的更改同步到数据库

生成迁移文件 :python3 manage.py makemigrations

执行迁移脚本: python3 manage.py migrate 该操作会同步到数据库

7)Meta类

通常是定义在model里的内部类,模型的元数据,指的是“除了字段外的所有内容”,例如排序方式、数据库表名、人类可读的单数或者复数名等等。例如:

from django.db import models
​
class Ox(models.Model):
    horn_length = models.IntegerField()
​
    class Meta:         # 注意,是模型的子类,要缩进!
        ordering = ["horn_length"]
        verbose_name_plural = "oxen"

常用属性:

属性名 含义 样例
ordering 排序 ["horn_length"],列表,-horn_length表示降序
abstract 被设置位抽象模型,不生成数据表 abstract=True
db_table 数据库中的数据表名
unique_together 唯一联合索引 unique_together=['day','hour']
index_together 普通联合索引
constraints 约束条件 constraints = [ models.CheckConstraint(check=models.Q(age__gte=18), name='age_gte_18'), ]
verbose_name 字段标签名 verbose_name = "披萨",通常用于展示

参考:django 模型的元数据Meta - 刘江的django教程文章来源地址https://www.toymoban.com/news/detail-426456.html

到了这里,关于day4-Django的model的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL——day4

    单表查询练习 -- 1. 查询出部门编号为30的所有员工 mysql select * from emp where deptno=30;   -- 2. 所有销售员的姓名、编号和部门编号。 mysql select ename,empno,deptno from emp where job=\\\'销售员\\\';   -- 3. 找出奖金高于工资的员工。 mysql select * from emp where commsai;   -- 4. 找出奖金高于工资60%的员工

    2024年02月15日
    浏览(22)
  • c++day4

    作业 仿照string类,完成myString 类 class myString { private: char *str; //记录c风格的字符串 int size; //记录字符串的实际长度 public: //无参构造 myString():size(10) { str = new char[size]; //构造出一个长度为10的字符串 strcpy(str,\\\"\\\"); //赋值为空串 } //有参构造 myString(const char *s) //string s(\\\"hello world\\\")

    2024年02月09日
    浏览(24)
  • Vue [Day4]

    App.vue components/HmFooter.vue App.vue HmButton.vue main.js HmFooter.vue components/BaseButton.vue App.vue 父 - 子 props components/SonTest.vue App.vue prop概念 components/UserInfo.vue App.vue props校验 类型校验 基础写法+完整写法 components/BaseProgress.vue App.vue prop data 、单向数据流 components/BaseProgress.vue App.vue 子 - 父

    2024年02月14日
    浏览(34)
  • QT【day4】

    chat_QT服务器端: 思维导图:

    2024年02月14日
    浏览(35)
  • 瑞吉外卖day4

    介绍  服务端要接收客户端页面上传的文件,通常都会使用Apache的两个组件 1.commons-file upload 2.commons-io Spring框架在spring-web包中对文件上传进行了封装。只需要在Controller的方法中声明一个MultipartFile类型的参数即可接受上传的文件 代码实现 upload方法里的形参名要保证与前端提

    2024年02月04日
    浏览(33)
  • Qt : day4

    1.思维导图  2.服务器  3.时钟  

    2024年02月15日
    浏览(30)
  • ARM day4

    1、实现LED1/LED2/LED3三盏灯循环点亮熄灭(统一上传链接,代码截图、实验现象图片) led 2、思维导图  

    2024年02月16日
    浏览(38)
  • day4 2/21

    2024年02月21日
    浏览(25)
  • 前端DAY4

    学习CSS的盒子模型。 px:像素;em:相对元素font-size的倍数;rem:相对根(即html)字体大小;%:相对父元素来进行计算。 注:CSS中设置长度必须加单位,否则样式无效 。 1.块元素 特点 1.在页面中独占一行 2.默认宽度:撑满父元素。默认高度:由内容撑开 3.可以通过CSS设置宽高

    2024年02月19日
    浏览(22)
  • 【QT】Day4

    1 思维导图 2 手动完成服务器的实现,并具体程序要注释清楚  widget.h widget.cpp  

    2024年02月15日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包