映射關係 表名<---------->類名 字段<---------->屬性 表記錄<-------->類示例對象
映射關係
表名<---------->類名
字段<---------->屬性
表記錄<-------->類示例對象
實例: 下面建立的是一個關於書的表 class Books(models.Model): bid = models.AutoField(primary_key=True) bname = models.CharField(max_length=32) bauthor = models.CharField(max_length=16) bprice = models.DecimalField(max_digits=5,decimal_places=2) bdata = models.DateField() #建立一個類,類名稱就是表名,建立類必定要繼承models.Model。上述實例中bid,bname就至關因而表中的字段,注意相應的參數。id能夠本身寫,可是必需要加上primmary_key=True,也能夠不寫,Django會本身添加。 #在models中建立完類以後,在命令行中執行: python manage.py makemigrations python manage.py migrate #版本不同的能夠去查一下,新版本都是執行上述命令生成相應的表。 #Django默認是sqlit3的數據庫,若是用的mysql能夠在settings中修改參數: DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql',#mysql就是你想用的數據庫 'NAME': "books",#數據庫名稱 "USER": "root",#用戶 "PASSWORD":"",#密碼 "HOST":"",#用戶 "PORT":"3306"#端口 } } #執行完以後就能夠在數據庫中查到相應的表,第一次建立會生成不少表,用Django建立的表的名稱是‘應用名+類名’(推薦使用Navcite數據庫可視化工具,方便修改) #若是想查看本身的建立的表的sql命令,能夠在setting中添加: LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'handlers': { 'console':{ 'level':'DEBUG', 'class':'logging.StreamHandler', }, }, 'loggers': { 'django.db.backends': { 'handlers': ['console'], 'propagate': True, 'level':'DEBUG', }, } } #這樣執行的時候能夠在終端顯示sql命令。
實例:
下面建立的是一個關於書的表
class Books(models.Model):
bid = models.AutoField(primary_key=True)
bname = models.CharField(max_length=32)
bauthor = models.CharField(max_length=16)
bprice = models.DecimalField(max_digits=5,decimal_places=2)
bdata = models.DateField()
#建立一個類,類名稱就是表名,建立類必定要繼承models.Model。上述實例中bid,bname就至關因而表中的字段,注意相應的參數。id能夠本身寫,可是必需要加上primmary_key=True,也能夠不寫,Django會本身添加。
#在models中建立完類以後,在命令行中執行:
python manage.py makemigrations
python manage.py migrate
#版本不同的能夠去查一下,新版本都是執行上述命令生成相應的表。
#Django默認是sqlit3的數據庫,若是用的mysql能夠在settings中修改參數:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',#mysql就是你想用的數據庫
'NAME': "books",#數據庫名稱
"USER": "root",#用戶
"PASSWORD":"",#密碼
"HOST":"",#用戶
"PORT":"3306"#端口
}
}
#執行完以後就能夠在數據庫中查到相應的表,第一次建立會生成不少表,用Django建立的表的名稱是‘應用名+類名’(推薦使用Navcite數據庫可視化工具,方便修改)
#若是想查看本身的建立的表的sql命令,能夠在setting中添加:
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console':{
'level':'DEBUG',
'class':'logging.StreamHandler',
},
},
'loggers': {
'django.db.backends': {
'handlers': ['console'],
'propagate': True,
'level':'DEBUG',
},
}
}
#這樣執行的時候能夠在終端顯示sql命令。
#每一個字段有一些特有的參數,例如,CharField須要max_length參數來指定VARCHAR數據庫字段的大小。還有一些適用於全部字段的通用參數。 這些參數在文檔中有詳細定義,這裏咱們只簡單介紹一些最經常使用的: 1.null 若是爲True,Django將用NULL在書庫中存儲控制。默認是False。 2.blank 若是爲True,該字段永續不填。默認爲False,要注意,這與NULL不一樣。Null純粹是數據庫範疇的,而blank是數據驗證的,若是一個字段的Blank爲True,表單的驗證將容許該字段是空值,若是blank=true,該字段就是必填的。 3.default 字段的默認值。能夠是一個值或者爲調用對象,若是可調用 ,每有新對象被建立它都會被調用。 4.primary_key 若是爲True,那麼這個字段就是模型的主鍵。若是你沒有指定任何一個字段的primary_key=True,Django 就會自動添加一個IntegerField字段作爲主鍵,因此除非你想覆蓋默認的主鍵行爲,不然不必設置任何一個字段的primary_key=True。 5.unique 若是該值設置爲 True, 這個數據字段的值在整張表中必須是惟一的。 6.choices 由二元組組成的一個可迭代的帝鄉,用來給字段提供選擇項。若是設置了choices,默認的表單講師一個選擇框而不是標準的文本框,並且這個選擇框的選項就是choices中的選項。 #示例: YEAR_IN_SCHOOL_CHOICES = ( ('FR', 'Freshman'), ('SO', 'Sophomore'), ('JR', 'Junior'), ('SR', 'Senior'), ('GR', 'Graduate'), ) 7.auto_now 和 auto_now_add auto_now 自動建立---不管添加或修改,都是當前操做的時間, auto_now_add 自動建立---永遠是建立時的時間 8.auto_created=False 自動建立 9.db_index =True 數據庫索引 10.max_length 最大長度
#每一個字段有一些特有的參數,例如,CharField須要max_length參數來指定VARCHAR數據庫字段的大小。還有一些適用於全部字段的通用參數。 這些參數在文檔中有詳細定義,這裏咱們只簡單介紹一些最經常使用的:
1.null
若是爲True,Django將用NULL在書庫中存儲控制。默認是False。
2.blank
若是爲True,該字段永續不填。默認爲False,要注意,這與NULL不一樣。Null純粹是數據庫範疇的,而blank是數據驗證的,若是一個字段的Blank爲True,表單的驗證將容許該字段是空值,若是blank=true,該字段就是必填的。
3.default
字段的默認值。能夠是一個值或者爲調用對象,若是可調用 ,每有新對象被建立它都會被調用。
4.primary_key
若是爲True,那麼這個字段就是模型的主鍵。若是你沒有指定任何一個字段的primary_key=True,Django 就會自動添加一個IntegerField字段作爲主鍵,因此除非你想覆蓋默認的主鍵行爲,不然不必設置任何一個字段的primary_key=True。
5.unique
若是該值設置爲 True, 這個數據字段的值在整張表中必須是惟一的。
6.choices
由二元組組成的一個可迭代的帝鄉,用來給字段提供選擇項。若是設置了choices,默認的表單講師一個選擇框而不是標準的文本框,並且這個選擇框的選項就是choices中的選項。
#示例:
YEAR_IN_SCHOOL_CHOICES = (
('FR', 'Freshman'),
('SO', 'Sophomore'),
('JR', 'Junior'),
('SR', 'Senior'),
('GR', 'Graduate'),
)
7.auto_now 和 auto_now_add
auto_now 自動建立---不管添加或修改,都是當前操做的時間,
auto_now_add 自動建立---永遠是建立時的時間
8.auto_created=False
自動建立
9.db_index =True
數據庫索引
10.max_length
最大長度
a=models.AutoField #自增列=int() #若是沒有的話,默認會生成一個名稱爲id的列,若是要顯示的自定義一個自增列,必須講給列設置主鍵 primary_key=true b=models.CharField #字符串字段 #必須有max_length參數 c=models.BooleanField #布爾類型=tinyint(1) #不能爲空blank=True d=models.CommaSeparatedIntegerField #用逗號分割的數字=varchar #繼承CharField,因此必須有max_length參數 e=models.DateField #日期類型的Date #對於參數,auto_now=True則每次跟新都是更新這個時間;auto_now_add則只是第一次建立添加,以後的更新將再也不改變 f=models.DecimalField #十進制小數的類型 #必須制定整數位max_digits(總位數長度)和小數位decimal_places g=models.EmailField #字符串誒性(正則表達式郵箱)=varchar #對字符串進行正則表達式 h=models.IntegerField #整形 i=models.TimeField #時間 HH:MM[:ss[.uuuuuu]] j=models.TextField #字符串=longtext k=models.ImageField #圖片 l=models.FilePathField #文件
a=models.AutoField #自增列=int()
#若是沒有的話,默認會生成一個名稱爲id的列,若是要顯示的自定義一個自增列,必須講給列設置主鍵 primary_key=true
b=models.CharField #字符串字段
#必須有max_length參數
c=models.BooleanField #布爾類型=tinyint(1)
#不能爲空blank=True
d=models.CommaSeparatedIntegerField #用逗號分割的數字=varchar
#繼承CharField,因此必須有max_length參數
e=models.DateField #日期類型的Date
#對於參數,auto_now=True則每次跟新都是更新這個時間;auto_now_add則只是第一次建立添加,以後的更新將再也不改變
f=models.DecimalField #十進制小數的類型
#必須制定整數位max_digits(總位數長度)和小數位decimal_places
g=models.EmailField #字符串誒性(正則表達式郵箱)=varchar
#對字符串進行正則表達式
h=models.IntegerField #整形
i=models.TimeField #時間 HH:MM[:ss[.uuuuuu]]
j=models.TextField #字符串=longtext
k=models.ImageField #圖片
l=models.FilePathField #文件
#添加普通字段 #方式一 books_obj=models.Books(bname="追風箏的人",bauthor="卡勒德·胡賽尼",bprice="111.88",bdata="2003-10-10") books_obj.save() #方式二 books_obj=models.Books.objects.create(bname="追風箏的人",bauthor="卡勒德·胡賽尼",bprice="111.88",bdata="2003-10-10") #注:id能夠不添加,數據庫會自動添加
#添加普通字段
#方式一
books_obj=models.Books(bname="追風箏的人",bauthor="卡勒德·胡賽尼",bprice="111.88",bdata="2003-10-10")
books_obj.save()
#方式二
books_obj=models.Books.objects.create(bname="追風箏的人",bauthor="卡勒德·胡賽尼",bprice="111.88",bdata="2003-10-10")
#注:id能夠不添加,數據庫會自動添加
#方式一 book_obj=models.Books.objects.filter(bid=i) book_obj.bname="天才在左瘋子在右" book_obj.bauthor="高銘" book_obj.bdata="2010-10-10" book_obj.bprice="28.60" book_obj.save() #方式二 models.Books.objects.filter(id=id).update(bname="天才在左瘋子在右",bauthor="高銘",bdata="2010-10-10",bprice="28.60") #此外,update()方法對於任何結果集(QuerySet)均有效,這意味着你能夠同時更新多條記錄update()方法會返回一個整型數值,表示受影響的記錄條數。
#方式一
book_obj=models.Books.objects.filter(bid=i)
book_obj.bname="天才在左瘋子在右"
book_obj.bauthor="高銘"
book_obj.bdata="2010-10-10"
book_obj.bprice="28.60"
book_obj.save()
#方式二
models.Books.objects.filter(id=id).update(bname="天才在左瘋子在右",bauthor="高銘",bdata="2010-10-10",bprice="28.60")
#此外,update()方法對於任何結果集(QuerySet)均有效,這意味着你能夠同時更新多條記錄update()方法會返回一個整型數值,表示受影響的記錄條數。
#刪除方法就是 delete()。它運行時當即刪除對象而不返回任何值。 #刪除方法就是 delete()。它運行時當即刪除對象而不返回任何值。 models.Books.objects.filter(id=id).delete()
#刪除方法就是 delete()。它運行時當即刪除對象而不返回任何值。
#刪除方法就是 delete()。它運行時當即刪除對象而不返回任何值。
models.Books.objects.filter(id=id).delete()
#查詢相關的參數 <1> all(): 查詢全部結果 <2> filter(**kwargs): 它包含了與所給篩選條件相匹配的對象 <3> get(**kwargs): 返回與所給篩選條件相匹配的對象,返回結果有且只有一個, 若是符合篩選條件的對象超過一個或者沒有都會拋出錯誤。 <5> exclude(**kwargs): 它包含了與所給篩選條件不匹配的對象 <4> values(*field): 返回一個ValueQuerySet——一個特殊的QuerySet,運行後獲得的並非一系列 model的實例化對象,而是一個可迭代的字典序列 <9> values_list(*field): 它與values()很是類似,它返回的是一個元組序列,values返回的是一個字典序列 <6> order_by(*field): 對查詢結果排序 <7> reverse(): 對查詢結果反向排序 <8> distinct(): 從返回結果中剔除重複紀錄 <10> count(): 返回數據庫中匹配查詢(QuerySet)的對象數量。 <11> first(): 返回第一條記錄 <12> last(): 返回最後一條記錄 <13> exists(): 若是QuerySet包含數據,就返回True,不然返回False #雙下劃綫查詢 models.Tb1.objects.filter(id__lt=10, id__gt=1) # 獲取id大於1 且 小於10的值 models.Tb1.objects.filter(id__in=[11, 22, 33]) # 獲取id等於十一、2二、33的數據 models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in models.Tb1.objects.filter(name__contains="ven") models.Tb1.objects.filter(name__icontains="ven") # icontains大小寫不敏感 models.Tb1.objects.filter(id__range=[1, 2]) # 範圍bettwen and
#查詢相關的參數
<1> all(): 查詢全部結果
<2> filter(**kwargs): 它包含了與所給篩選條件相匹配的對象
<3> get(**kwargs): 返回與所給篩選條件相匹配的對象,返回結果有且只有一個,
若是符合篩選條件的對象超過一個或者沒有都會拋出錯誤。
<5> exclude(**kwargs): 它包含了與所給篩選條件不匹配的對象
<4> values(*field): 返回一個ValueQuerySet——一個特殊的QuerySet,運行後獲得的並非一系列
model的實例化對象,而是一個可迭代的字典序列
<9> values_list(*field): 它與values()很是類似,它返回的是一個元組序列,values返回的是一個字典序列
<6> order_by(*field): 對查詢結果排序
<7> reverse(): 對查詢結果反向排序
<8> distinct(): 從返回結果中剔除重複紀錄
<10> count(): 返回數據庫中匹配查詢(QuerySet)的對象數量。
<11> first(): 返回第一條記錄
<12> last(): 返回最後一條記錄
<13> exists(): 若是QuerySet包含數據,就返回True,不然返回False
#雙下劃綫查詢
models.Tb1.objects.filter(id__lt=10, id__gt=1) # 獲取id大於1 且 小於10的值
models.Tb1.objects.filter(id__in=[11, 22, 33]) # 獲取id等於十一、2二、33的數據
models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in
models.Tb1.objects.filter(name__contains="ven")
models.Tb1.objects.filter(name__icontains="ven") # icontains大小寫不敏感
models.Tb1.objects.filter(id__range=[1, 2]) # 範圍bettwen and