欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django如何自定義model創(chuàng)建數(shù)據(jù)庫(kù)索引的順序

 更新時(shí)間:2019年06月20日 08:27:43   作者:628 財(cái)經(jīng)  
這篇文章主要介紹了Django如何自定義model創(chuàng)建數(shù)據(jù)庫(kù)索引的順序,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

首先這是一個(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í)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python的sqlite3模塊中常用函數(shù)

    Python的sqlite3模塊中常用函數(shù)

    sqlite3模塊是Python中的內(nèi)置模塊,用于與SQLite數(shù)據(jù)庫(kù)交互,本文就來介紹一下Python的sqlite3模塊中常用函數(shù),感興趣的可以了解一下
    2023-10-10
  • Python實(shí)現(xiàn)修改文件內(nèi)容的方法分析

    Python實(shí)現(xiàn)修改文件內(nèi)容的方法分析

    這篇文章主要介紹了Python實(shí)現(xiàn)修改文件內(nèi)容的方法,結(jié)合實(shí)例形式分析了Python文件讀寫、字符串替換及shell方法調(diào)用等相關(guān)操作技巧,需要的朋友可以參考下
    2018-03-03
  • 詳解Python3中yield生成器的用法

    詳解Python3中yield生成器的用法

    這篇文章主要介紹了詳解Python3中yield生成器的用法,是Python入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-08-08
  • python sort、sorted高級(jí)排序技巧

    python sort、sorted高級(jí)排序技巧

    這篇文章主要介紹了python sort、sorted高級(jí)排序技巧,本文講解了基礎(chǔ)排序、升序和降序、排序的穩(wěn)定性和復(fù)雜排序、cmp函數(shù)排序法等內(nèi)容,需要的朋友可以參考下
    2014-11-11
  • Python從入門到精通之環(huán)境搭建教程圖解

    Python從入門到精通之環(huán)境搭建教程圖解

    這篇文章主要介紹了Python從入門到精通之環(huán)境搭建,需要的朋友可以參考下
    2019-09-09
  • python中文本字符處理的簡(jiǎn)單方法記錄

    python中文本字符處理的簡(jiǎn)單方法記錄

    這篇文章主要給大家介紹了關(guān)于python中文本字符處理的簡(jiǎn)單方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • python實(shí)現(xiàn)樹形打印目錄結(jié)構(gòu)

    python實(shí)現(xiàn)樹形打印目錄結(jié)構(gòu)

    這篇文章主要為大家詳細(xì)介紹了python樹形打印目錄結(jié)構(gòu)的相關(guān)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • 基于Python的關(guān)鍵字監(jiān)控及告警

    基于Python的關(guān)鍵字監(jiān)控及告警

    這篇文章主要為大家詳細(xì)介紹了基于Python的關(guān)鍵字監(jiān)控及告警,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • 詳解如何在Apache中運(yùn)行Python WSGI應(yīng)用

    詳解如何在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-01
  • Python+fuzzywuzzy計(jì)算兩個(gè)字符串之間的相似度

    Python+fuzzywuzzy計(jì)算兩個(gè)字符串之間的相似度

    fuzzywuzzy?可以計(jì)算兩個(gè)字符串之間的相似度,它依據(jù)?Levenshtein?Distance?算法來進(jìn)行計(jì)算,該算法又叫?Edit?Distance?算法,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2022-09-09

最新評(píng)論