Django如何自定義model創(chuàng)建數(shù)據(jù)庫(kù)索引的順序
首先這是一個(gè)先有雞還是先有蛋的問題,大部分時(shí)候數(shù)據(jù)都來自excel的整理,當(dāng)數(shù)據(jù)越來越多,需要分析的點(diǎn)也越來越多的時(shí)候,通過excel來管理顯然有些吃力了。
這時(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ì)提示未定義(這部分不做舉例)。
接下來創(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è)過程會(huì)看到系統(tǒng)在創(chuàng)建數(shù)據(jù)表。
創(chuàng)建好以后再添加總表中的索引字段,首先可以肯定的是model是按照字母順序創(chuàng)建索引的,如果沒有其他的models.ForeignKey,可以直接通過字母順序來控制索引的創(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ù)有一千萬條 每次條件過濾 省10%的數(shù)據(jù)
1 如果三個(gè)單索引 先拿a的索引找 剩下100萬數(shù)據(jù) 然后拿b條件找 剩十萬 再c條件找 最后得到一萬數(shù)據(jù)
2 如果是聯(lián)合索引 他 一千萬數(shù)據(jù)*10% * 10% * 10% 直接得到一萬條數(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)建表的問題
- 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)文章
Python實(shí)現(xiàn)修改文件內(nèi)容的方法分析
這篇文章主要介紹了Python實(shí)現(xiàn)修改文件內(nèi)容的方法,結(jié)合實(shí)例形式分析了Python文件讀寫、字符串替換及shell方法調(diào)用等相關(guān)操作技巧,需要的朋友可以參考下2018-03-03python實(shí)現(xiàn)樹形打印目錄結(jié)構(gòu)
這篇文章主要為大家詳細(xì)介紹了python樹形打印目錄結(jié)構(gòu)的相關(guān)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03詳解如何在Apache中運(yùn)行Python WSGI應(yīng)用
在生產(chǎn)環(huán)境上,一般會(huì)使用比較健壯的Web服務(wù)器,如Apache來運(yùn)行我們的應(yīng)用,本文中我們就會(huì)介紹如何使用Apache模塊mod_wsgi來運(yùn)行Python WSGI應(yīng)用。感興趣的小伙伴們可以參考一下2019-01-01Python+fuzzywuzzy計(jì)算兩個(gè)字符串之間的相似度
fuzzywuzzy?可以計(jì)算兩個(gè)字符串之間的相似度,它依據(jù)?Levenshtein?Distance?算法來進(jìn)行計(jì)算,該算法又叫?Edit?Distance?算法,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-09-09