电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Django中的AutoField字段使用

瀏覽:176日期:2024-10-05 16:51:01

【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.labelAssertionError: 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字段使用就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 招商帮-一站式网络营销服务|搜索营销推广|信息流推广|短视视频营销推广|互联网整合营销|网络推广代运营|招商帮企业招商好帮手 | 复盛空压机配件-空气压缩机-复盛空压机(华北)总代理 | 冷凝水循环试验箱-冷凝水试验箱-可编程高低温试验箱厂家-上海巨为(www.juweigroup.com) | 数年网路-免费在线工具您的在线工具箱-shuyear.com | 广东机电安装工程_中央空调工程_东莞装饰装修-广东粤标建设有限公司 | 钢制拖链生产厂家-全封闭钢制拖链-能源钢铝拖链-工程塑料拖链-河北汉洋机械制造有限公司 | 天一线缆邯郸有限公司_煤矿用电缆厂家_矿用光缆厂家_矿用控制电缆_矿用通信电缆-天一线缆邯郸有限公司 | R507制冷剂,R22/R152a制冷剂厂家-浙江瀚凯制冷科技有限公司 | 【孔氏陶粒】建筑回填陶粒-南京/合肥/武汉/郑州/重庆/成都/杭州陶粒厂家 | 电机铸铝配件_汽车压铸铝合金件_发动机压铸件_青岛颖圣赫机械有限公司 | 南京泽朗生物科技有限公司 | 两头忙,井下装载机,伸缩臂装载机,30装载机/铲车,50装载机/铲车厂家_价格-莱州巨浪机械有限公司 | 猪I型/II型胶原-五克隆合剂-细胞冻存培养基-北京博蕾德科技发展有限公司 | 龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司_龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司 | 南京泽朗生物科技有限公司-液体饮料代加工_果汁饮料代加工_固体饮料代加工 | 槽钢冲孔机,槽钢三面冲,带钢冲孔机-山东兴田阳光智能装备股份有限公司 | 成都离婚律师|成都结婚律师|成都离婚财产分割律师|成都律师-成都离婚律师网 | 灌装封尾机_胶水灌装机_软管灌装封尾机_无锡和博自动化机械制造有限公司 | 台湾阳明固态继电器-奥托尼克斯光电传感器-接近开关-温控器-光纤传感器-编码器一级代理商江苏用之宜电气 | 云杂志网-学术期刊-首页 | 苏州柯瑞德货架-仓库自动化改造解决方案 | 吲哚菁绿衍生物-酶底物法大肠菌群检测试剂-北京和信同通科技发展有限公司 | 经济师考试_2025中级经济师报名时间_报名入口_考试时间_华课网校经济师培训网站 | _网名词典_网名大全_qq网名_情侣网名_个性网名 | 合肥展厅设计-安徽展台设计-合肥展览公司-安徽奥美展览工程有限公司 | 标准品网_标准品信息网_【中检计量】 | 重庆网站建设,重庆网站设计,重庆网站制作,重庆seo,重庆做网站,重庆seo,重庆公众号运营,重庆小程序开发 | 工业用品一站式采购平台|南创工品汇-官网|广州南创 | 百度网站优化,关键词排名,SEO优化-搜索引擎营销推广 | 留学生辅导网-在线课程论文辅导-留学生挂科申诉机构 | 青岛球场围网,青岛车间隔离网,青岛机器人围栏,青岛水源地围网,青岛围网,青岛隔离栅-青岛晟腾金属制品有限公司 | 净化板-洁净板-净化板价格-净化板生产厂家-山东鸿星新材料科技股份有限公司 | 糖衣机,除尘式糖衣机,全自动糖衣机,泰州市长江制药机械有限公司 体感VRAR全息沉浸式3D投影多媒体展厅展会游戏互动-万展互动 | 无尘烘箱_洁净烤箱_真空无氧烤箱_半导体烤箱_电子防潮柜-深圳市怡和兴机电 | 珠光砂保温板-一体化保温板-有釉面发泡陶瓷保温板-杭州一体化建筑材料 | 伸缩器_伸缩接头_传力接头-巩义市润达管道设备制造有限公司 | 烟台游艇培训,威海游艇培训-烟台市邮轮游艇行业协会 | 今日扫码_溯源二维码_产品防伪一物一码_红包墙营销方案 | 不锈钢酒柜|恒温酒柜|酒柜定制|酒窖定制-上海啸瑞实业有限公司 | 柔软云母板-硬质-水位计云母片组件-首页-武汉长丰云母绝缘材料有限公司 | 六维力传感器_三维力传感器_二维力传感器-南京神源生智能科技有限公司 |