教育行業(yè)A股IPO第一股(股票代碼 003032)

全國咨詢/投訴熱線:400-618-4000

Django orm的基本使用方法之一

更新時間:2018年12月13日13時35分 來源:傳智播客 瀏覽次數(shù):

ORM( Object relational mapping 對象關(guān)系映射
D:把面向?qū)ο笾械念惡蛿?shù)據(jù)庫表一一對應(yīng)起來,在django項目與數(shù)據(jù)庫之間起著橋梁的                
    角色
E:通過操作類和對象,對數(shù)據(jù)庫表實現(xiàn)數(shù)據(jù)的增刪改查等操作,而不需要寫SQL語句
    使用ORM可以通過方便的配置,切換使用不同的數(shù)據(jù)庫
U:①使用django進行數(shù)據(jù)庫開發(fā)步驟:
    1. 在models.py中定義模型類(生成表名為應(yīng)用名_模型類名小寫)
2. 生成遷移文件: python manage.D呃py makemigrations
3. 執(zhí)行遷移生成數(shù)據(jù)庫表(默認使用sqlite3數(shù)據(jù)庫,生成的數(shù)據(jù)庫名為:db.sqlite3): python manage.py migrate
4. 安裝sqliteman:sudo apt-get install sqliteman;啟動:sqliteman
5. 通過模型類和對象,對數(shù)據(jù)進行增刪改查

通過ORM對數(shù)據(jù)庫增刪改:
可以進入交互模式執(zhí)行代碼:python manage.py shell
創(chuàng)建模型類對象:a = 模型類()
增/改:a.save()   --------不指定id則默認使用上一次id,第一次為1,如果指定id,id不存
                        在則添加數(shù)據(jù),id存在則修改數(shù)據(jù),如id =None,則id=上一次id+1
刪除:a.delete()  --------不指定id即刪除本次id

字段屬性(即數(shù)據(jù)表中對應(yīng)的字段):
屬性名 = models.字段類型(字段限制)  ------屬性名不可以用python關(guān)鍵字及雙下劃線
字段類型:
字段類型 類型含義 描述
AutoField 自動增長的整數(shù)字段 通常不需要指定,Django會自動創(chuàng)建屬性名為id的自動增長屬性
BooleanField 布爾字段 值為True或False
NullBooleanField 空布爾字段 支持Null、True、False三種值。
CharField  字符串字段 必須指定參數(shù)(max_length=字符個數(shù))
TextField 大文本字段 一般超過4000個字符時使用
DateField,TimeField,DateTimeField 日期, 時間, 日期時間字段 可指定參數(shù)auto_now=False(True:保存對象,django自動為該屬性賦值,默認為False);auto_now_add(True:第一次創(chuàng)建,django自動為該屬性賦值,默認為False)
IntegerField 整數(shù)字段 從 -2147483648 到 2147483647 范圍內(nèi)的值是合法的
DecimalField 十進制浮點數(shù) 必須指定參數(shù)(max_digit=總位數(shù),decimal_places=小數(shù)后位數(shù))
FloatField 浮點數(shù) 用python中的float來表示,有誤差
FileField 上傳文件字段
ImageField 圖片字段 繼承于FileField,對上傳的內(nèi)容進行校驗,確保是有效的圖片


字段選項(即數(shù)據(jù)表中字段限制):
選項 默認值 描述 是否要重新遷移修改表結(jié)構(gòu)
null False True:數(shù)據(jù)庫中字段允許為空
unique False True:值必須唯一
db_column 屬性名稱 字段名,如果未指定,則使用屬性的名稱
db_index False True:為此字段創(chuàng)建索引。 查看索引:show index from 表名
primary_key False True:則該字段會成為模型的主鍵字段,一般作為AutoField的選項使用
default 為字段設(shè)置默認值
blank False True:html頁面表單驗證時字段允許為空


通過ORM查詢數(shù)據(jù)庫:
objects(模型管理器)
D:每個模型類都有一個objects的類屬性,由django字段生成
E:查詢數(shù)據(jù)庫的數(shù)據(jù)或?qū)?shù)據(jù)進行操作處理


U:objects中的方法:
objects管理器中的方法 返回類型 作用
模型類.objects.get() 模型對象 返回一個對象,且只能有一個: 如果查到多條數(shù)據(jù),則報:MultipleObjectsReturned 如果查詢不到數(shù)據(jù),則報:DoesNotExist
模型類.objects.filter() QuerySet 返回滿足條件的對象
模型類.objects.all() QuerySet 返回所有的對象
模型類.objects.exclude() QuerySet 返回不滿條件的對象
模型類.objects.order_by() QuerySet 對查詢結(jié)果集進行排序
模型類.objects.aggregate() 字典,例如:{'salary__avg': 9500.0} 進行聚合操作 Sum, Count, Max, Min, Avg
模型類.objects.count() 數(shù)字 返回查詢集中對象的數(shù)目


filter方法
D:模型管理器objects的一種查詢方法
E:實現(xiàn)條件查詢,返回QuerySet對象,包含了所滿足條件的數(shù)據(jù)
U:模型類.objects.filter(模型類屬性名__條件名 = 值)
filter條件:
條件 含義 注釋
exact 判等 可以省略
contains; endswith; startswith 模糊查詢 包含; 以什么開頭; 結(jié)尾
isnull 空查詢 是否為空,是返回True,否返回False
in 范圍查詢 在....內(nèi)
gt,lt,gte,lte 比較查詢 大于,小于,大于等于,小于等于
year, date 日期查詢 年,日期


查詢的其他方式
方法 作用 示例
F對象 引用某字段的值,對比表中的兩個字段 查詢語文分數(shù)大于數(shù)學分數(shù)的學生 成績表.objects.filter(語文__gt=F('數(shù)學'))
Q對象 組合多個查詢條件,通過(&,|,~)進行邏輯操作 Q(條件1)邏輯操作符 Q(條件2) 
order_by 對查詢結(jié)果進行排序(默認升序) 升序: 模型類.objects.order_by('字段名') 降序: 模型類.objects.order_by('-字段名')
aggregate 聚合操作,對多行查詢結(jié)果中的一列進行操作,返回一個值。(有Sum,Count,Max,Min,Avg) 模型類.objects.aggregate(聚合類('模型屬性')) 返回值是一個字典,格式: {'屬性名__聚合函數(shù)': 值}
count 統(tǒng)計滿足條件的對象的個數(shù),返回值是一個數(shù)字 模型類.objects.count()


查看orm語句
打開mysqld.cnf sudo vi /etc/mysql/mysql.conf.d/mysqld.cnf
重啟mysql服務(wù) sudo service mysql restart
查看mysql日志內(nèi)容 sudo tail -f /var/log/mysql/mysql.log


QuerySet查詢集
D:調(diào)用模型管理器的all, filter, exclude, order_by方法會產(chǎn)生一個QuerySet
E:先過濾得到該查詢集還可以調(diào)用objects的方法操作數(shù)據(jù)
U:①取下標操作(下標不允許負數(shù)):b[0]取出QuerySet的第一條數(shù)據(jù),如果不存在則                
    拋異常
    ②切片操作(下標不允許負數(shù)):產(chǎn)生新的QuerySet
    ③get():取出QuerySet的唯一一條數(shù)據(jù),不存在或者多條則拋異常
    ④exsit():判斷是否有數(shù)據(jù)
    ⑤改,刪數(shù)據(jù)庫數(shù)據(jù):QuerySet對象.update(屬性1=值1),QuerySet.delete()
特性:①惰性查詢:只有在使用QuerySet中的數(shù)據(jù)時,才會取查詢數(shù)據(jù)庫中的數(shù)據(jù)
        ②緩存:第一次遍歷QuerySet中的所有對象,django會把數(shù)據(jù)緩存起來,第二次再使用時會使                
        用緩存,不會再次查詢。

一對多關(guān)聯(lián)查詢
由一類的條件查詢多類數(shù)據(jù)
1.   一類對象 = 一類類名.objects.get(條件)
    一類對象.多類類名小寫_set.all()
2.  多類類名.objects.filter(一類類名小寫__一類屬性名__條件 = 值)

由多類的條件查詢一類數(shù)據(jù)
1.   多類對象 = 多類類名.objects.get(條件)
    多類對象.關(guān)聯(lián)屬性
2.   一類類名.objects.filter(多類類名小寫__多類屬性名__條件 =值 )

自關(guān)聯(lián)
D:是一種特殊的一對多關(guān)系
U:自關(guān)聯(lián)關(guān)聯(lián)屬性定義:關(guān)聯(lián)屬性 = models.ForeignKey('self')

自定義模型管理器
D:在模型類中自定義模型管理器,自定義后,Django將不再生成默認的objects
E: 功能1:修改管理器返回的原始查詢集
    功能2:在管理器類中添加額外的方法,幫助我們操作模型類對應(yīng)的數(shù)據(jù)表,減輕視
                    圖函數(shù)中的代碼量,主要做邏輯處理。
U:①在views創(chuàng)建一個自定義模型管理器類,繼承Manager
    ②重寫父類的方法修改管理器返回的原始查詢集
    ③把操作數(shù)據(jù)庫的代碼實現(xiàn)封裝到模型管理器的方法中,返回模型類對象
    ④在原模型類中:objects=自定義模型管理器類名()    實現(xiàn)功能1
    ⑤在視圖函數(shù)中調(diào)用objects.③的方法名()   可實現(xiàn)功能2

作者:傳智播客人工智能+Python培訓學院
首發(fā):http://python.itcast.cn/
0 分享到:
和我們在線交談!