Django如何自定義model創(chuàng)建數(shù)據(jù)庫(kù)索引的順序
首先這是一個(gè)先有雞還是先有蛋的問(wèn)題,大部分時(shí)候數(shù)據(jù)都來(lái)自excel的整理,當(dāng)數(shù)據(jù)越來(lái)越多,需要分析的點(diǎn)也越來(lái)越多的時(shí)候,通過(guò)excel來(lái)管理顯然有些吃力了。
這時(shí)候就需要將excel導(dǎo)入到數(shù)據(jù)庫(kù)中,然而model創(chuàng)建的索引并非是我們編寫時(shí)候的順序,特別是當(dāng)存在 models.ForeignKey 時(shí),我們必須要先創(chuàng)建 ForeignKey的class,最后再創(chuàng)建總表。
為了保證數(shù)據(jù)庫(kù)的索引跟excel的索引一致,我們需要對(duì)model中的索引字段做一系列的處理(可能這是一個(gè)野路子)。
首先當(dāng)然是先創(chuàng)建好ForeignKey,這部分class要寫在前面,否則總表的class對(duì)于引用的ForeignKey會(huì)提示未定義(這部分不做舉例)。
接下來(lái)創(chuàng)建總表,此時(shí)不要著急去填寫總表中的索引字段,只先創(chuàng)建這個(gè)總表的表頭,如下圖:
@python_2_unicode_compatible class ZZ_Demo(models.Model): #此處的ZZ開頭的命名是為了讓這個(gè)class在最后創(chuàng)建 ######中間什么都不要寫###### class Meta: verbose_name = '這是個(gè)Demo' verbose_name_plural = '這是個(gè)Demo' #這些是在Django admin里顯示的 可忽略 def __str__(self): return self.name
然后在終端執(zhí)行:
python manage.py makemigrations python manage.py migrate
這個(gè)過(guò)程會(huì)看到系統(tǒng)在創(chuàng)建數(shù)據(jù)表。
創(chuàng)建好以后再添加總表中的索引字段,首先可以肯定的是model是按照字母順序創(chuàng)建索引的,如果沒(méi)有其他的models.ForeignKey,可以直接通過(guò)字母順序來(lái)控制索引的創(chuàng)建順序,如下圖所示:
@python_2_unicode_compatible class ZZ_Demo(models.Model): ab_productline = models.ForeignKey(ProductLine, verbose_name=u'產(chǎn)品線',default=1,null=True) ac_name = models.CharField(max_length=50, verbose_name = u'故障名稱',null=True) ...... bn_casetags = models.CharField(max_length=50, verbose_name = u'關(guān)鍵詞 標(biāo)簽 備注',default=None,blank=True,null=True) class Meta: verbose_name = '這是個(gè)Demo' verbose_name_plural = '這是個(gè)Demo' def __str__(self): return self.be_casenumber
這樣創(chuàng)建好的索引就完全是字母順序排列了,小伙伴們可以試試看。
Django model 中設(shè)置聯(lián)合約束和聯(lián)合索引
在Django model中對(duì)一張表的幾個(gè)字段進(jìn)行聯(lián)合約束和聯(lián)合索引,例如在購(gòu)物車表中,登錄的用戶和商品兩個(gè)字段在一起表示唯一記錄。
舉個(gè)栗子:
Django model中購(gòu)物車表
class Cart(models.Model): user = models.ForeignKey( MyUser, verbose_name="用戶" ) goods = models.ForeignKey( Goods, verbose_name="商品" ) num = models.IntegerField( verbose_name="商品數(shù)量" ) is_select = models.BooleanField( default=True, verbose_name="選中狀態(tài)" ) class Meta: # 聯(lián)合約束 其中g(shù)oods和user不能重復(fù) unique_together = ["goods", "user"] # 聯(lián)合索引 index_together = ["user", "goods"]
unique_together = ["goods", "user"] 表示聯(lián)合約束,其中"goods"和"user"表示不能重復(fù),不能一樣。
index_together = ["user", "goods"] 表示聯(lián)合索引,其中"goods"和"user"聯(lián)合同步查詢,提高效率。
聯(lián)合索引的優(yōu)勢(shì)
示例SQL:select * from person where a=100 and b=100 and c=1000;
假設(shè)你的數(shù)據(jù)有一千萬(wàn)條 每次條件過(guò)濾 省10%的數(shù)據(jù)
1 如果三個(gè)單索引 先拿a的索引找 剩下100萬(wàn)數(shù)據(jù) 然后拿b條件找 剩十萬(wàn) 再c條件找 最后得到一萬(wàn)數(shù)據(jù)
2 如果是聯(lián)合索引 他 一千萬(wàn)數(shù)據(jù)*10% * 10% * 10% 直接得到一萬(wàn)條數(shù)據(jù)
建立聯(lián)合索引的同時(shí) 還會(huì)給他們之間的組合建立索引
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 對(duì)Django 中request.get和request.post的區(qū)別詳解
- 基于Django URL傳參 FORM表單傳數(shù)據(jù) get post的用法實(shí)例
- 教你如何將 Sublime 3 打造成 Python/Django IDE開發(fā)利器
- Python+Django在windows下的開發(fā)環(huán)境配置圖解
- python Django連接MySQL數(shù)據(jù)庫(kù)做增刪改查
- Django中對(duì)數(shù)據(jù)查詢結(jié)果進(jìn)行排序的方法
- Django中幾種重定向方法
- Python的Django框架中forms表單類的使用方法詳解
- python Django模板的使用方法(圖文)
- Django objects.all()、objects.get()與objects.filter()之間的區(qū)別介紹
- 教你安裝python Django(圖文)
- Django中更新多個(gè)對(duì)象數(shù)據(jù)與刪除對(duì)象的方法
- Django框架中render_to_response()函數(shù)的使用方法
- Django靜態(tài)資源URL STATIC_ROOT的配置方法
- 解決Django migrate No changes detected 不能創(chuàng)建表的問(wèn)題
- django啟動(dòng)uwsgi報(bào)錯(cuò)的解決方法
- 詳解Django框架中用戶的登錄和退出的實(shí)現(xiàn)
- Django讀取Mysql數(shù)據(jù)并顯示在前端的實(shí)例
- Django小白教程之Django用戶注冊(cè)與登錄
- Python3+Django get/post請(qǐng)求實(shí)現(xiàn)教程詳解
相關(guān)文章
python3.7 利用函數(shù)os pandas利用excel對(duì)文件名進(jìn)行歸類
這篇文章主要介紹了python3.7 利用函數(shù)os pandas利用excel對(duì)文件名進(jìn)行歸類,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
numpy中np.append()函數(shù)用法小結(jié)
在numpy的函數(shù)庫(kù)中,np.append()函數(shù)是一個(gè)常用的數(shù)組操作函數(shù),它在進(jìn)行數(shù)組操作時(shí)能夠?qū)蓚€(gè)數(shù)組進(jìn)行拼接,并返回一個(gè)拼接后的新數(shù)組,下面就來(lái)介紹一下具體用法,感興趣的可以了解一下2023-11-11
Python辦公自動(dòng)化批量處理文件實(shí)現(xiàn)示例
這篇文章主要為大家介紹了Python辦公自動(dòng)化批量處理文件實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06
Django 使用easy_thumbnails壓縮上傳的圖片方法
今天小編就為大家分享一篇Django 使用easy_thumbnails壓縮上傳的圖片方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-07-07
Tornado協(xié)程在python2.7如何返回值(實(shí)現(xiàn)方法)
下面小編就為大家?guī)?lái)一篇Tornado協(xié)程在python2.7如何返回值(實(shí)現(xiàn)方法)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06

