博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django Model 模型建立
阅读量:6085 次
发布时间:2019-06-20

本文共 1995 字,大约阅读时间需要 6 分钟。

hot3.png

Django Model 模型

Django Model层是Django的数据模型层,每一个Model类就是数据库中的一张表;

我们需要注意下面几点:

  • model一般都是定义在不同的APP的models.py模块文件中,可以是一个,也可以是多个;

  • 不同model之间可以相互关联,类似表直接的关联;

  • APP中一旦定义了model,必须将此APP添加到settings文件中;

  • 且一定要记得运行makemigrations检查model更新和migrate同步数据模型在数据库中建表(这两个操作大家记得在哪里操作吗,之前的文章有写,快捷键就是Alt+Ctrl+R);

如何定义一个数据model模型

我们一起来看一下如何定义一个数据model模型,具体有哪些操作:

  • 首先我们需要在APP中的models.py创建Model,我们用courses APP来操作一下
from django.db import modelsclass Course(models.Model):    name = models.CharField(max_length=50, verbose_name="课程名")    desc = models.CharField(max_length=300, verbose_name=u"课程描述")    degree = models.CharField(choices=(("primary", '初级'), ("middle","中级"), ("junior", "高级")), max_length=10, verbose_name='课程难度')    students = models.IntegerField(default=0, verbose_name="学习人数")    # 需要安装pillow,图片处理库    image = models.ImageField(upload_to="courses/%Y/%m", verbose_name="课程图片", max_length=100)    class Meta:        verbose_name = "课程"        verbose_name_plural = verbose_name

我们知道每一个Model类就是数据库中的一张表,那这段代码中我们定义了五个字段,代表相应的数据库表中也有五个字段,大家注意一下字段的类型(等一下我们再来讲解关于字段类型), 这个表其实就想当于以下代码:

create table courses_course(    id int not null primary key,    name varchar(50),    desc varchar(300),    degree varchar(10),    students int(11),    image varchar(100),);

然后我们需要在数据库中生成数据表,执行makemigrations在app下建立migrations目录,并记录下所有关于models.py的改动,比如0001_initial.py, 但是这个改动还没有作用到数据库文件,接着执行migrate将改动作用到数据库文件,比如产生table之类;

最后可以登录mysql数据库检查表是否创建成功,大家还记得怎么登录mysql数据库吗? 先开启mysql数据库,我是用的Winginx中的mysql数据库,所以我只需要在Winginx打开就好,然后在命令行工具中输入:

mysql -ufirst_project -p123456我的用户名是first_project ,密码是123456

然后我们在数据库中查看表是否成功

use First_Project   # 我的数据库是First_Project  show tables;  # 查看所有表

数据库表.jpg 我们是不是能看到有一个courses_course表呀,然后输入命令行desc courses_course; 查看表字段.jpg

Field 字段类型

IntegerField:整型字段;

CharField:字符型字段,该字段类型有一个必需参数:max_length 在数据库水平限定了字符串最大长度;

ImageField:图像字段,能自动验证上传的对象是否为合法的图像;

FloatField:浮点字段;

AutoField:根据已有id自增长的整型唯字段,一般每个model类不需设置该字段,因为django会为每个model自动设置;

我这里列举了几个比较常用的字段类型,大家如果想知道更多可以查看Django官方文档:

参考视频:

转载于:https://my.oschina.net/u/4072026/blog/3052499

你可能感兴趣的文章
redis的简单安装配置
查看>>
Linux用户与用户组的详解
查看>>
《Java并发编程实战》第十四章 构建自己定义的同步工具 读书笔记
查看>>
INTERIGHT 京东自营旗舰店-京东 要把凡客给弄残啊这是。。
查看>>
编程算法 - 有序双循环链表的插入 代码(C)
查看>>
基于TcpListener的web服务器
查看>>
readv和writev函数
查看>>
SPA与DPA 攻击【转】
查看>>
RPi 2B apache2 mysql php5 and vsftp
查看>>
同一TextView上内容的不同显示
查看>>
android linearlayout 把控件view置底部(放在页面最下方)
查看>>
ios inHouse 公布应用
查看>>
正则表达式------去掉字符串前后所有空格
查看>>
C#百万数据查询超时问题
查看>>
2016第10周五
查看>>
使用gson-1.6.jar解析json
查看>>
AC Milan VS Juventus(模拟)
查看>>
CentOS两台服务器利用scp拷贝文件
查看>>
【云计算】Ubuntu14.04 搭建GlusterFS集群
查看>>
SQL DatePart函数使用
查看>>