【Django是一个机智的框架】
默认情况下Djang会为ORM中定义的每一张表加上一个自增ID列,并且用这个列来做主键;出于一个MySQL-DBA的工作经历我觉得
Djanog还真是机智;这样么说主要是因为我遇到过许多主从延时的问题,有些比较过分的会延时好几周,通常这些都是因为binlog格式
为“ROW”但是表上不存在主键引起的。
如果当前网站用的是Django开发的,我想就不会有这种事情发生了吧。
【AutoField】
Django默认的行为就像这样
class TestModel(models.Model):
id = models.AutoField(primary_key=True)
数据库层面对应的SQL如下
CREATE TABLE `myapp_testmodel` ( `id` int(11) NOT NULL AUTO_INCREMENT, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8
【注意】
如果你想的工增加AutoField列,但是又不指定这个列做为主键的话,是会报错的
class TestModel(models.Model):
tid = models.AutoField()
不显示指定主键,但是又给表增加AutoField列的话就会报错
assert not cls._meta.auto_field, "Model %s can't have more than one AutoField." % cls._meta.label
AssertionError: Model myapp.TestModel can't have more than one AutoField.
补充知识:Django中models下常用Field以及字段参数
一、常见的FieldType数据库字段类型
1、AutoField:自增Field域,自动增加的一个数据库字段类型,例如id字段就可以使用该数据类型,参数中必须填入primary_key=True
2、BigAutoField:和AutoField相同,只是比AutoField要大,参数中必须填入primary_key=True
3、BigIntegerField:大整型,只要用于存储整型的数据
4、BinaryField:主要是存储原始的二进制数据
5、BooleanField:主要是存储布尔类型的数据,0和1
6、CharField:主要存储字符串的数据类型
7、DateField:主要存储日期类型的数据类型,日期格式为YYYY-MM-DD
8、DateTimeField:主要存储时间相关的数据类型,格式为YYYY-MM-DD HH:MM:[ss[.uuuuuu]][TZ]
注意:DateField与DateTimeField有两个属性,配置auto_now_add=True,创建数据记录的时候会把当前时间添加到数据库,配置auto_now=True,每次更新数据记录的时候都会更新该字段
9、DecimalField:主要存储固定精度的十进制数据
--参数:max_digits(小数总长度)/decimal_places(小数位长度)
10、EmailField:存储电子邮件格式的数据,Django Admin以及ModelForm中提供验证机制
11、FileField:存储文件类型的数据,文件上传到指定目录
--参数:upload_to="...."(上传文件的保存路径)/storage=None(存储组件,默认django.core.files.storage.FileSystemStorage)
12、FilePathField:存储文件路径的数据,提供读取文件夹下文件的功能
--参数:path(文件夹路径)/match=None(正则匹配)/recursive=False(递归下面的文件夹)/allow_files=True(允许文件)/allow_folders=False(允许文件夹)
13、FloatField:存储浮点型数据
14、ImageField:存储图片型数据,文件上传到指定目录
--参数:upload_to="....."(上传文件的保存路径)/storage=None(存储组件,默认django.core.files.storage.FileSystemStorage)/width_field=None(上传图片的宽度保存的数据库字段名<字符串>)/height_field=None(上传图片的高度保存的数据库字段名<字符串>)
15、IntegerField:存储整型数据
16、GenericIPAddressField:存储IP地址信息数据
17、NullBooleanField:可以存储布尔值数据,也可以存储空null数据
18、PositiveIntegerField:主要存储正整数数据
19、SmallIntegerField:小整型,主要用于存储整型的数据
20、TextField:存储文章内容信息数据,存储比较长的文本信息
21、TimeField:存储时间信息
22、URLField:存储URL网址信息,Django Admin以及ModelForm中提供验证url
23、IPAddressField:Django Admin以及ModelForm中提供验证IPV4机制
24、GenericIPAddressField:Django Admin以及ModelForm中提供验证IPV4和IPV6机制
二、常用关系型数据表处理Field
1、处理一对多关系数据表:使用ForeignKey
2、处理多对多关系数据表:使用ManyToManyField
三、字段参数
1、null:用于表示某个字段可以为空
2、unique:如果设置为unique=True则该字段在此表中必须是唯一的
3、db_index:如果db_index=True则代表这为此字段设置索引
4、default:为该字段设置默认值
四、关系字段
1、to:设置要关联的表
2、to_field:设置要关联的表的字段
3、related_name:反向操作时,使用的字段名,用于代替原反向查询时的"表名_set"
4、on_delete:当删除关联表中的数据时,当前表与其关联的行的行为,例如删除一个出版社,那么和这个出版社有关联的书籍也都被删除掉了,下面介绍on_delete的参数值:
on_delete=models.CASCADE:删除关联数据,与之关联也删除
on_delete=models.DO_NOTHING:删除关联数据,引发错误IntegrityError
on_delete=models.PROTECT:删除关联数据,引发错误ProtectedError
on_delete=models.SET_NULL:删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空)
on_delete=models.SET_DEFAULT:删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值)
on_delete=models.SET:删除关联数据:
a、与之关联的值设置为指定值,设置:models.SET(值)
b、与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)
5、db_constraint:是否在数据库中创建外键约束,默认为True,db_constraint一般使用在建立数据表连接关系当中(例如创建外键),如果使用False,则是限制了表之间没有关联,达到了软连接的效果
五、元信息
ORM对应的类里面包含另一个Meta类,而Meta类封装了一些数据库的信息,主要字段如下:
1、db_table:ORM在数据库中的表名默认为app_类名,可以通过db_table可以重写表名
2、index_together:联合索引,给两列做索引
3、unique_together:联合唯一索引,两列不能重复
4、ordering:指定默认按什么字段顺序,只有设置了该属性,我们查询到的结果才可以被reverse()
具体介绍可以查看https://docs.djangoproject.com/en/dev/ref/models/fields/
以上这篇Django中的AutoField字段使用就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]