如何使用Django和Postgres進行全文搜索-創新互聯

這篇文章主要介紹如何使用Django和Postgres進行全文搜索,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

成都創新互聯是一家專業提供防城港企業網站建設,專注與成都網站設計、成都做網站H5技術、小程序制作等業務。10年已為防城港眾多企業、政府機構等服務。創新互聯專業網站建設公司優惠進行中。

項目及其要求

您可能已經注意到,我正在運行工作板。 Voorjob基本上是從lever.co聚合工作,并讓用戶搜索它。目前,我在數據庫中大約有25,000個工作,這個數字增長緩慢,每增加2或3個工作,就會關閉另一個工作。是的,如果我采用了彈性搜索路徑,那將是一本教科書過度設計的情況。

實施

從9.4版開始,postgres添加了一些允許全文本搜索的功能。不久之后,Django在postgres特定功能中鏡像了這些功能。

要開始使用此新功能,我基本上需要在模型中使用SearchVectorField,并需要使用矢量化的職位描述來更新此字段的方法:

from django.contrib.postgres.search import SearchVectorField, SearchVector
class Job(models.Model):
  title = models.CharField(max_length=200, blank=True)
  location = models.CharField(max_length=50, blank=True)
  body = models.TextField(null=True)
  body_vector = SearchVectorField(null=True)
 
  def make_search_vector():
    self.body_vector=SearchVector('body')
 
  def save(self, *args, **kwargs):
    self.make_search_vector()
    super(Model, self).save(*args, **kwargs)

這種方法適用于很少更新的工作,例如工作板,但是如果您的應用程序經常更新,則應避免使用此策略,并應定期執行一些任務來填充向量:

Job.objects.all().update(body_vector=SearchVector('body'))

甚至更好的是,您可以通過閱讀本文檔,使用postgres觸發器直接進行操作。

查詢工作

現在您已經準備好數據庫,現在可以查詢它了,讓我們看一下voorjob搜索視圖的教學版本:

from django.contrib.postgres.search import SearchQuery
 
class Index(ListView):
  model = Job
  paginate_by = 30
 
  def get_queryset(self):
    search = self.request.GET.get("search", None)
    queryset = Job.objects.all()
 
    if search:
      if '"' in search:
        query = SearchQuery(search.replace('"', ''), search_type='phrase')
      else:
        query = SearchQuery(search)
      queryset = queryset.filter(body_vector=query)
    else:
      queryset = queryset
 
    return queryset

我基本上在這里考慮兩種查詢:單詞存在和“精確表達式”。是的,該邏輯中存在一些缺陷,請繼續起訴我:D

還有很多可以改進的地方,django支持加權查詢:

vector = SearchVector('title',weight ='A')+ SearchVector('body',weight ='B')
Job.objects.all()。update(body_vector = vector)

這最終將以更好的順序返回結果,其中標題中的匹配比正文中的匹配更重。

查詢系統也更加靈活,允許進行邏輯運算OR / AND和NOT。在不久的將來,我將改善對工作板的搜索,并更新此帖子以描述所做的更改。

性能

在開發過程中,我使用了具有16GB內存和不錯的NVMe的I5。對本地計算機中的25k作業運行查詢基本上是瞬時的。

當我將項目轉移到生產環境時(每滴5美元),事情變得越來越慢了。

運行密西西比基準測試,我得到以下結果:

在/ django rest framework上搜索((1個密西西比州以掃描5K條目))

在/ full /上搜索“ django rest framework”(-3個密西西比州,掃描25K條目)

不是最好的性能,但現在可以使用。本文將進行更新以反映任何性能改進。

考慮到我的搜索需求不高-超過25k的條目,且字數過多的文章并不比本文大很多-使用postgres作為我的全文搜索的后端,對于此早期MVP來說效果很好。現在,我比每天給我20個用戶提供最快的體驗,對嘗試事物和擴大董事會成員更感興趣。

更新(2020年2月9日)

好消息! 我了解到可以將索引添加到SearchVectorField中:

from django.contrib.postgres.indexes import GinIndex
 
class Job(models.Model):
  class Meta:
    indexes = (GinIndex(fields=["body_vector"]),)
  title = models.CharField(max_length=200, blank=True)
  location = models.CharField(max_length=50, blank=True)
  body = models.TextField(null=True)
  body_vector = SearchVectorField(null=True)
  def make_search_vector():
    self.body_vector=SearchVector('body')
  def save(self, *args, **kwargs):
    self.make_search_vector()
    super(Model, self).save(*args, **kwargs)

現在,所有情況下的搜索時間均降至1個密西西比州。 由于我的數據很小,因此用于該索引的內存量可以忽略不計。

以上是“如何使用Django和Postgres進行全文搜索”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯成都網站設計公司行業資訊頻道!

另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

網站標題:如何使用Django和Postgres進行全文搜索-創新互聯
本文鏈接:http://m.kartarina.com/article10/ccjogo.html

成都網站建設公司_創新互聯,為您提供網站維護手機網站建設品牌網站制作企業網站制作電子商務全網營銷推廣

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

網站建設網站維護公司
主站蜘蛛池模板: 无码国产福利av私拍| 亚洲精品无码专区久久久| 国产爆乳无码视频在线观看| 中国少妇无码专区| 91久久九九无码成人网站| 本道久久综合无码中文字幕| 无码人妻精品一区二区三区夜夜嗨| 久久久无码精品午夜| 亚洲国产精品无码专区| 天堂无码在线观看| 无码福利写真片视频在线播放| 亚洲欧洲日产国码无码久久99 | 丰满少妇人妻无码专区| 性无码免费一区二区三区在线| 日韩夜夜高潮夜夜爽无码| 亚洲成A∨人片在线观看无码| a级毛片无码免费真人久久| 无码狠狠躁久久久久久久| 亚洲AV无码无限在线观看不卡 | 亚洲最大中文字幕无码网站| heyzo高无码国产精品| 国产精品无码专区在线播放| 少妇仑乱A毛片无码| 中文字幕av无码无卡免费| 亚洲AV人无码综合在线观看| 岛国无码av不卡一区二区| 野花在线无码视频在线播放| 无码AV一区二区三区无码| 一本色道无码道在线| 无码AV一区二区三区无码| 无码专区国产无套粉嫩白浆内射| 精品人妻无码一区二区三区蜜桃一| 999久久久无码国产精品| 亚洲中文字幕无码av在线| 亚洲AV无码久久寂寞少妇| 亚洲AV无码一区东京热| 亚洲成A人片在线观看无码3D| 伊人久久一区二区三区无码| 无码欧精品亚洲日韩一区| 无码人妻精品一区二区| 手机永久无码国产AV毛片|