Django models.py應(yīng)用實現(xiàn)過程詳解
編寫 models.py 文件
from django.db import models # Create your models here. class User_info(models.Model): username = models.CharField(max_length=25,verbose_name='用戶名') password = models.CharField(max_length=25,verbose_name='密碼') age = models.IntegerField() e_mail = models.EmailField() create_time = models.DateTimeField() update_time = models.DateTimeField()
字段類型
一般數(shù)據(jù)庫中字段類型大概5種(字符串/數(shù)字/浮點型/時間類型/布爾類型),但Django為了在后臺admin中可以操作數(shù)據(jù)庫,同時為了限制在admin中對數(shù)據(jù)庫的無效操作,Model中設(shè)置了很多種數(shù)據(jù)類型。
1、models.AutoField 自增列=int(11) 如果沒有的話,默認會生成一個名稱為id的列,如果要顯示的定義一個自增列,必須把該列設(shè)置為主鍵(primary_key=True) 2、models.CharField 字符串類型字段 必須加max_length參數(shù) 3、models.BooleanField 布爾類型字段=tinyint(1) 不能為空,Blank=True 4、models.ComaSeparatedIntegerField 用逗號分割的數(shù)字類型=varchar 繼承CharField,所以必須加max_lenght參數(shù) 5、models.DateField 日期字段類型date 參數(shù)auto_now=True表示每次更新都會更新這個時間;參數(shù)auto_now_add表示只是第一次創(chuàng)建時添加,之后的更新不再改變 6、models.DateTimeField 日期字段類型datetime 同DateField的參數(shù) 7、models.Decimal 十進制小數(shù)類型=decimal 必須指定整數(shù)位max_digits和小數(shù)位decimal_places 8、models.EmailField 字符串類型(正則表達式郵箱)=varchar 對字符串進行正則表達式驗證 9、models.FloatField 浮點類型=double 10、models.IntegerField 整形 11、models.BigIntegerField 長整形 integer_field_ranges = { 'SmallIntegerField': (-32768, 32767), 'IntegerField': (-2147483648, 2147483647), 'BigIntegerField': (-9223372036854775808, 9223372036854775807), 'PositiveSmallIntegerField': (0, 32767), 'PositiveIntegerField': (0, 2147483647), } 12、models.IPAddressField 字符串類型(ip4正則表達式) 13、models.GenericIPAddressField 字符串類型(ip4和ip6是可選的) 參數(shù)protocol可以是:both、ipv4、ipv6 驗證時,會根據(jù)設(shè)置進行報錯 14、models.NullBooleanField 允許為空的布爾類型 15、models.PositiveIntegerFiel 正Integer 16、models.PositiveSmallIntegerField 正smallInteger 17、models.SlugField 減號、下劃線、字母、數(shù)字 18、models.SmallIntegerField 數(shù)字 數(shù)據(jù)庫中的字段有:tinyint、smallint、int、bigint 19、models.TextField 字符串=longtext 20、models.TimeField 時間 HH:MM[:ss[.uuuuuu]] 21、models.URLField 字符串類型,地址正則表達式 22、models.BinaryField 二進制 23、models.ImageField 圖片 24、models.FilePathField 文件
執(zhí)行命令:
# 執(zhí)行以下命令,記錄我們對models.py的所有改動 python manage.py makemigrations
執(zhí)行后生成如下文件
# Generated by Django 2.1.2 on 2018-12-11 11:39 from django.db import migrations, models class Migration(migrations.Migration): initial = True dependencies = [ ] operations = [ migrations.CreateModel( name='User_info', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('username', models.CharField(max_length=25, verbose_name='用戶名')), ('password', models.CharField(max_length=25, verbose_name='密碼')), ('age', models.IntegerField()), ('e_mail', models.EmailField(max_length=254)), ('create_time', models.DateTimeField()), ('update_time', models.DateTimeField()), ], ), ]
代碼如下
#如下 這條命令的主要作用就是把這些改動作用到數(shù)據(jù)庫也就是執(zhí)行migrations里面新改動的遷移文件更新數(shù)據(jù)庫,比如創(chuàng)建數(shù)據(jù)表,或者增加字段屬性 python manage.py migrate
執(zhí)行該命令后 數(shù)據(jù)庫生成如下數(shù)據(jù)庫表
如上圖得到的表名 是以應(yīng)用名命名的,但是不是我們想要的怎么辦了,增加兩行代碼
如下:
from django.db import models # Create your models here. from django.db import models class User_info(models.Model): username = models.CharField(max_length=25,verbose_name='用戶名') password = models.CharField(max_length=25,verbose_name='密碼') age = models.IntegerField() e_mail = models.EmailField() create_time = models.DateTimeField() update_time = models.DateTimeField() class Meta: db_table = 'User_info'
修改代碼重新執(zhí)行
# 執(zhí)行以下命令,記錄我們對models.py的所有改動 python manage.py makemigrations
此時新生成了 一個migrations 文件
此時可以針對 新的文件進行執(zhí)行
python manage.py migrate ModelMysql 0002_auto_20181211_1150
查看數(shù)據(jù)庫表得到新建的數(shù)據(jù)表
python manage.py makemigrations這個命令是記錄我們對models.py的所有改動,并且將這個改動遷移到migrations這個文件下生成一個文件例如:0001文件,如果你接下來還要進行改動的話可能生成就是另外一個文件不一定都是0001文件,但是這個命令并沒有作用到數(shù)據(jù)庫,這個剛剛我們在上面的操作過程之后已經(jīng)看到了。
而當我們執(zhí)行python manage.py migrate 命令時 這條命令的主要作用就是把這些改動作用到數(shù)據(jù)庫也就是執(zhí)行migrations里面新改動的遷移文件更新數(shù)據(jù)庫,比如創(chuàng)建數(shù)據(jù)表,或者增加字段屬性
另外一個需要注意的是這兩個命令默認情況下是作用于全局,也就是對所有最新更改的models或者migrations下面的遷移文件進行對應(yīng)的操作,如果要想僅僅對部分app進行作用的話 則執(zhí)行如下命令:
python manage.py makemigrations appname python manage.py migrate appname
如果要想精確到某一個遷移文件則可以使用:
python manage.py migrate appname 文件名
遇到問題:
1、
No migrations to apply(django不能創(chuàng)建數(shù)據(jù)庫中的表的問題)
如下圖:
解決辦法:
第一步:
刪除該app名字下的migrations下除__init__.py外的文件。
第二步:
進入數(shù)據(jù)庫,找到django_migrations的表,刪除該app名字的所有記錄。
第三步:執(zhí)行下面這兩條命令:(在項目目錄下)
python manage.py makemigrations python manage.py migrate
原因:
django_migrations表記錄著數(shù)據(jù)庫的對應(yīng)表的修改記錄。
每次修改后,都執(zhí)行第三步的命令,然后在第一步的文件夾下生成修改的文件,django_migrations表記錄修改的變更過程。
2、
Warning: (3135, "'NO_ZERO_DATE', 'NO_ZERO_IN_DATE' and 'ERROR_FOR_DIVISION_BY_ZERO' sql modes should be used with strict mode. They will be merged with strict mode in a future release.") result = self._query(query)
修改options 如下:
# MySQL adil 密碼:helloyyj DATABASES = { 'default':{ 'ENGINE':'django.db.backends.mysql', 'HOST':'127.0.0.1', 'PORT':'3306', 'NAME':'pyweb', # 數(shù)據(jù)庫名 'USER':'adil', 'PASSWORD':'helloyyj', 'OPTIONS':{ 'sql_mode': 'traditional' }, } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 解決django同步數(shù)據(jù)庫的時候app models表沒有成功創(chuàng)建的問題
- Django 模型類(models.py)的定義詳解
- python Django中models進行模糊查詢的示例
- Django的models中on_delete參數(shù)詳解
- Django的models模型的具體使用
- django1.11.1 models 數(shù)據(jù)庫同步方法
- 淺談Django中的數(shù)據(jù)庫模型類-models.py(一對一的關(guān)系)
- Django中反向生成models.py的實例講解
- Django 根據(jù)數(shù)據(jù)模型models創(chuàng)建數(shù)據(jù)表的實例
- Django對models里的objects的使用詳解
相關(guān)文章
Python實現(xiàn)的遠程登錄windows系統(tǒng)功能示例
這篇文章主要介紹了Python實現(xiàn)的遠程登錄windows系統(tǒng)功能,結(jié)合實例形式分析了Python基于wmi模塊的遠程連接與進程操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2018-06-06Python?GUI利用tkinter皮膚ttkbootstrap實現(xiàn)好看的窗口
這篇文章主要介紹了Python?GUI利用tkinter皮膚ttkbootstrap實現(xiàn)好看的窗口,文章基于python的相關(guān)資料展開詳細的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下2022-06-06Pandas實現(xiàn)解析JSON數(shù)據(jù)與導(dǎo)出的示例詳解
其實使用pandas解析JSON?Dataset要方便得多,所以這篇文章主要為大家介紹了Pandas實現(xiàn)解析JSON數(shù)據(jù)與導(dǎo)出的具體方法,需要的小伙伴可以收藏一下2023-07-07解決pycharm最左側(cè)Tool Buttons顯示不全的問題
今天小編就為大家分享一篇解決pycharm最左側(cè)Tool Buttons顯示不全的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12