django之models模块使用
定义模型
将数据库表定义成类,集成models.Model
from django.db import models
# Create your models here.
class Author(models.Model):
name=models.CharField(max_length=100)
django会自动生成id字段作为主键,如果不定义主键的话
2,使用模型
将使用manage.py startapp XXX 创建的应用加入到setting下的INSTALLED_APPS下面,注意它为元组,别忘记后面的逗号
确保运行命令manage.py migrate,可以事先使用manage.py makemigrations 给应用生成迁移脚本。
3,字段
字段类型
模型中的每一个字段是field子类的实例
CharField和TextField字段都是最基本的保存文本的字段,其中Charfield是指定固定长度的,另一个是无限长的
DataField和DatatimeField字段是保存时间的字段
FileField是保存文件路径的字段
也可以自己自定义字段类型
字段选项
Null,如果为True,则将数据库中空值保存为NULL,默认为False
Blank,如果为True,则表单的验证允许为空值,默认为False,他是表单输入验证范畴的
Choice,由二维元组提供一些选项,设置了choice,表单是一个选择框,而不是文本框
Default,字段的默认值,可以是一个值或者可调用对象
Help_text,表单部件额外显示的帮助信息
Primary_key,如果为True,则该字段为主键,如果表中没有设置该值,django自动生成Id字段为主键
Unique,如果为True,这个数据字段在整个表中都是唯一的
关系
Django提供了最常见的三种数据库关系:多对一,多对多,一对一
多对一关系
Django使用 django.db.models.ForeignKey 定义多对一关系,和使用其他字段类型一样,在模型中把它作为类的属性包含进来
class Author(models.Model):
name=models.CharField(max_length=100)
class Book(models.Model):
title=models.CharField(max_length=100)
author=models.ForeignKey(Author) #定义了多对一的关系
length=models.IntegerField()
若要创建一个递归的关联 —— 对象与自己具有多对一的关系 —— 请使用models.ForeignKey('self')。
如果你需要关联到一个还没有定义的模型,你可以使用模型的名字而不用模型对象本身:
from django.db import models
class Car(models.Model):
manufacturer = models.ForeignKey('Manufacturer')
class Manufacturer(models.Model):
# ...
Pass
多对多关系
ManyToManyField 用来定义多对多关系,用法和其他Field 字段类型一样:在模型中做为一个类属性包含进来。
在哪个模型中使用ManytoManyField并不重要,在两个模型中任选一个即可,不用两个模型都设置
class Book(models.Model):
title=models.CharField(max_length=100)
author=models.ForeignKey(Author)
length=models.IntegerField() class classify(models.Model):
name=models.CharField(max_length=100)
books=models.ManyToManyField(Book) #定义多对多的关系
也可以按照数据库sql定义多对多关系的形式,在定义另一个模型,对两个模型设置外键
一对一关系
OneToOneField用来定义一对一关系。 用法和其他字段类型一样:在模型里面做为类属性包含进来。
class Author(models.Model):
name=models.CharField(max_length=100) class Authorinfo(models.Model):
phone=models.CharField(max_length=20)
add=models.CharField(max_length=300)
sex=models.CharField(choices=sex_choice)
author=models.OneToOneField(Author)
模型方法
可以在模型上定义自定义的方法来给你的对象添加自定义的“底层”功能。Manager 方法用于“表范围”的事务,模型的方法应该着眼于特定的模型实例。
如def __str__(self) #适用于python3
Return xxx
对于python2使用
Def __unicode__(self)
Return xxx
多表集成
Django的model中提供表之间的集成关系,每一层级下面的models是一个完整的model。在父表中的字段在字表中都有效,只是没有保存在字表中
具体的用法参考官网
django之models模块使用的更多相关文章
- django的models模块查询方法
假定models中有一个类BookInfo 模块查询不同于sql语句,模块查询的结果会返回符合条件的整个一行的对象,或者多个对象组成的查询集. 查询集类似列表,有相似的方法. 1 model查询语句: ...
- Django之models模块
一.字段 1. AutoField(Field) int自增列,必须填入参数 primary_key=True 2.BigAutoField(AutoField) bigint自增列,必须填入参数 p ...
- 第三百零九节,Django框架,models.py模块,数据库操作——F和Q()运算符:|或者、&并且——queryset对象序列化
第三百零九节,Django框架,models.py模块,数据库操作——F()和Q()运算符:|或者.&并且 F()可以将数据库里的数字类型的数据,转换为可以数字类型 首先要导入 from dj ...
- 第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多
第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多.一对一.多对多 链表操作 链表,就是一张表的外键字段,连接另外一张表的主键字段 一对多 models.Forei ...
- 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- 第三百零六节,Django框架,models.py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置
Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...
- 七 Django框架,models.py模块,数据库操作——F和Q()运算符:|或者、&并且——queryset对象序列化
F()可以将数据库里的数字类型的数据,转换为可以数字类型 首先要导入 from django.db.models import F from django.shortcuts import rende ...
- 五 Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- 四 Django框架,models.py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置
Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...
随机推荐
- Jmeter -- HTTP Request Defaults HTTP请求默认值
一.HTTP Request Defaults的作用: 该组件可以为我们的http请求设置默认的值.假如,我们创建一个测试计划有很多个请求且都是发送到相同的server,这时我们只需添加一个Http ...
- HanLP极致简繁转换详细讲解
HanLP极致简繁转换详细讲解 作者: hankcs(大快高级研究员 hanlp项目负责人) 谈起简繁转换,许多人以为是小意思,按字转换就行了.事实上,汉语历史悠久,地域复杂,发展至今在字符级别存在“ ...
- 由于未能创建Visual C# 2015编译器,因此未能打开项目xxx。请重新安装Visual Studio。
解决方案1: 清除如下文件夹里的内容. %AppData%\Local\microsoft\VisualStudio\14.0\ComponentModelCache or C:\Users\DEL ...
- RedHat6.5安装zookeeper集群
版本号: Redhat6.5 zookeeper-3.4.6 JDK1.8 zookeeper下载 官网下载地址:https://mirrors.tuna.tsinghua.edu.cn/apac ...
- PICT测试工具的安装及使用
PICT工具就是在微软公司出品一款成对组合的命令行生成工具,现在已经对外提供,可以在互联网上下载到 .PICT 可以有效地按照两两测试的原理,进行测试用例设计.在使用PICT时,需要输入与测试用例相关 ...
- Excel技巧--使用温度计图让目标与实际对比更明显
如上图,有一业绩目标与实际值对比表格,我们可使用如上图右方的温度计图表来让数字对比更明显些. 做法: 1.选择该表格,点击插入-->柱形图,簇状柱形图. 2.右键点击图表“实际值”柱,点选“设置 ...
- 手机闪存速度测试工具,AndroBench
手机闪存速度测试工具,AndroBench
- 关于Java按键事件KeyEvent重点几步
按键事件可以利用键盘来控制和执行一些动作,或者从键盘上获取输入,只要按下,释放一个键或者在一个组件上敲击,就会触发按键事件.KeyEvent对象描述事件的特性(按下,放开,或者敲击一个键)和对应的值. ...
- 【linux】之常用命令-杂项
查看端口:lsof -i :80 二.内存大小[root@xbidc ~]# cat /proc/meminfo |grep MemTotalMemTotal: 1034612 kB[root@xbi ...
- ribbon的注解使用报错--No instances available for [IP]
使用RestTemplate类调用其他系统的url的时候,加上ribbon的注解@LoadBalanced上这个注解之后访问,就报错了. 报错如下: 因为这里你不能直接访问地址,需要把地址改成你所调用 ...