国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

fastapi結(jié)合Manticore Search、elasticsearch、mysql實現(xiàn)全文搜索

這篇具有很好參考價值的文章主要介紹了fastapi結(jié)合Manticore Search、elasticsearch、mysql實現(xiàn)全文搜索。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報違法"按鈕提交疑問。

1、將數(shù)據(jù)寫入到mysql中

  • 創(chuàng)建測試表
CREATE TABLE `student` (
  `sno` varchar(10) COLLATE utf8mb4_unicode_ci NOT NULL,
  `sname` varchar(20) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `sage` int(2) DEFAULT NULL,
  `ssex` varchar(5) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  `description` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL,
  PRIMARY KEY (`sno`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
  • 測試表插入數(shù)據(jù)
insert into student values ('s001','張三',23,'男','張三是個好學(xué)生'); 
insert into student values ('s002','李四',23,'男','張三是個好學(xué)生');  
insert into student values ('s003','吳鵬',25,'男','張三是個好學(xué)生');  
insert into student values ('s004','琴沁',20,'女','張三是個好學(xué)生');  
insert into student values ('s005','王麗',20,'女','張三是個好學(xué)生');  
insert into student values ('s006','李波',21,'男','張三是個好學(xué)生');  
insert into student values ('s007','劉玉',21,'男','張三是個好學(xué)生');  
insert into student values ('s008','蕭蓉',21,'女','張三是個好學(xué)生');  
insert into student values ('s009','陳蕭曉',23,'女','張三是個好學(xué)生');  
insert into student values ('s010','陳美',22,'女','張三是個好學(xué)生');
  • 表字段描述

fastapi結(jié)合Manticore Search、elasticsearch、mysql實現(xiàn)全文搜索,fastapi,elasticsearch,mysql

  • 字段意義
sno 學(xué)號
sname	學(xué)生姓名
sage	學(xué)生年齡
ssex	學(xué)生性別
description	學(xué)生描述

2、python安裝fastapi、elasticsearch框架、Manticore Search框架和mysql客戶端

pip install elasticsearch==8.8.2
pip install pymysql
pip install manticoresearch

# Uvicorn是一個ASGI服務(wù)器,用于運(yùn)行FastAPI應(yīng)用。
pip install uvicorn
pip install fastapi

3、將mysql的數(shù)據(jù)寫入到elasticsearch中

  • mysql數(shù)據(jù)同步到es
# mysql-to-es
# 本地es版本 8.8.2
# python es版本  8.8.2
import pymysql
from elasticsearch import Elasticsearch

def get_data():
    conn=pymysql.connect(host="localhost",port=3306,user="root",password="root",database="mydb")
    cursor=conn.cursor()
    sql="select * from student"
    t_header_sql = "desc student "
    cursor.execute(sql)
    results=cursor.fetchall()
    cursor.execute(t_header_sql)
    header_results = cursor.fetchall()
    conn.close()
    return results,header_results

def create_es_data():
    # es = Elasticsearch()
    es = Elasticsearch(
        [
            "https://192.168.10.1:9200",
        ],
        ca_certs="./path/to/http_ca.crt",	# es認(rèn)證證書,8.0版本后開始使用
        basic_auth=("elastic", "U4mRQUoVeQ+YMzcCFD1t"),
        request_timeout=3600
    )
    try:
        data_results,cloumns_results = get_data()
        for row in data_results:
            message = {}
            for i in range(len(row)):
                # print(cloumns_results[i][0], row[i])
                message[cloumns_results[i][0]] = row[i]

            print(message)
            es.index(index="student", document=message)
    except Exception as e:
        print("Error:" + str(e))

if __name__=="__main__":
    create_es_data()
  • es查看數(shù)據(jù)(Elasticvue插件)

fastapi結(jié)合Manticore Search、elasticsearch、mysql實現(xiàn)全文搜索,fastapi,elasticsearch,mysql

?文章來源地址http://www.zghlxwxcb.cn/news/detail-650262.html

4、將mysql的數(shù)據(jù)寫入到Manticore中

  • mysql數(shù)據(jù)同步到Manticore

注:Manticore 和 Mysql 使用pymysql即mysql客戶端

import pymysql

def get_data():
    conn = pymysql.connect(host="localhost", port=3306, user="root", password="root", database="mydb")
    cursor = conn.cursor()
    sql = "select * from student"
    t_header_sql = "desc student "
    cursor.execute(sql)
    results = cursor.fetchall()
    cursor.execute(t_header_sql)
    header_results = cursor.fetchall()
    header_tuple = tuple(x[0] for x in header_results)
    conn.close()
    return results, header_tuple

def inster_data_to_manticore():
    try:
        db = pymysql.connect(host='localhost', port=9306)
        print('manticoredb 連接成功!')
    except:
        print('something wrong!')

    if db:
        cursor = db.cursor()
        rows, header_tuple = get_data()
        header_str = str(header_tuple).replace("\'","")
        sql = 'drop table if exists students'
        cursor.execute(sql)
        db.commit()

        for row in rows:
            sql = f'INSERT INTO students{header_str} VALUES {row}'
            print(sql)
            cursor.execute(sql)
            db.commit()

if __name__ == '__main__':
    inster_data_to_manticore()
  • Manticore 數(shù)據(jù)查詢(工具Webyog SQLyog)

fastapi結(jié)合Manticore Search、elasticsearch、mysql實現(xiàn)全文搜索,fastapi,elasticsearch,mysql

?

5、elasticsearch查找類的封裝

  • es安全認(rèn)證連接(參考官網(wǎng))
  • 按fields查詢方法封裝,輸入?yún)?shù)fields 篩選器,query查詢字符串
# elasticsearch_query_class.py
from elasticsearch import Elasticsearch
class elasticsearchself():
    def __init__(self,index_name,index_type = '_doc'):
        self.es = Elasticsearch(
        [
            "https://192.168.10.1:9200",
        ],
        ca_certs="./path/to/http_ca.crt",
        basic_auth=("elastic", "U4mRQUoVeQ+YMzcCFD1t"),
        request_timeout=3600
        )
        self.index_name=index_name
        self.index_type=index_type

    def search_by_fields(self,query,fields,count:int=30):
        ds = {"multi_match": {"query": query,"fields": fields}}
        fields = ['sname','description']
        match_data=self.es.search(index=self.index_name,query=ds,size=count)
        return match_data

es=elasticsearchself(index_name="student")
query = "張三"
fields= ['sname','description']
match_data = es.search_by_fields(query,fields)
print(match_data)

6、Manticoresearch查找類的封裝

# manticoreself.py

import manticoresearch
from manticoresearch.api import search_api
from manticoresearch.model.search_request import SearchRequest

class manticoresearchself():
    def __init__(self, index_name):
        self.configuration = manticoresearch.Configuration(
        host = "http://127.0.0.1:9308"
        )
        self.index_name = index_name

    def search_all_text(self,query):
        with manticoresearch.ApiClient(self.configuration) as api_client:
            # Create an instance of the API class
            api_instance = search_api.SearchApi(api_client)

            # # Create SearchRequest
            # search_request = SearchRequest()
            # search_request.index='students'
            # # search_request.fulltext_filter=QueryFilter(23)
            # search_request.fulltext_filter =

            search_request = SearchRequest(
                index='students',
                query={
                    "match":
                        {
                            "*" : query
                        }
                },
            )

            # example passing only required values which don't have defaults set
            try:
                # Performs a search
                api_response = api_instance.search(search_request)
                # pprint(api_response)
                return api_response
            except manticoresearch.ApiException as e:
                print("Exception when calling SearchApi->search: %s\n" % e)


mc=manticoresearchself(index_name="student")
query = "s004"
match_data = mc.search_all_text(query)
match_data_dict = match_data.__dict__
print(match_data._hits._hits[0]["_source"])

7、fastapi實現(xiàn)elasticseach的全文檢索模糊查詢

# main.py
from fastapi import FastAPI
from elasticsearch_query_class import elasticsearchself
import json
import time

app = FastAPI()

@app.get("/get_es/{query}")
async def get_es(query):
    fields = ['*']
    es=elasticsearchself(index_name="student")
    time_start = time.time()  # 記錄開始時間
    data=es.search_by_fields(query,fields)
    time_end = time.time()  # 記錄結(jié)束時間
    address_data=data["hits"]["hits"]
    address_list=[]
    for item in address_data:
        address_list.append(item["_source"])
    time_sum = time_end - time_start  # 計算的時間差為程序的執(zhí)行時間,單位為秒/s
    address_list.append({"time_sum":time_sum})
    new_json=json.dumps(address_list,ensure_ascii=False)
    return json.loads(new_json)

思路: es創(chuàng)建篩選器列表fields,[*]表示所有字段,查詢體query

8、fastapi實現(xiàn)Manticoresearch的全文檢索篩選查詢

# main.py
from fastapi import FastAPI
from manticoreself import manticoresearchself
import json
import time

app = FastAPI()

@app.get('/get_mc/<query>')
async def get_mc(query):
    mc = manticoresearchself(index_name="student")
    time_start = time.time()  # 記錄開始時間
    data = mc.search_all_text(query)
    time_end = time.time()  # 記錄結(jié)束時間
    address_data = data._hits._hits
    address_list = []
    for item in address_data:
        address_list.append(item["_source"])

    time_sum = time_end - time_start  # 計算的時間差為程序的執(zhí)行時間,單位為秒/s
    address_list.append({"time_sum": time_sum})
    new_json = json.dumps(address_list, ensure_ascii=False)
    return json.loads(new_json)

思路: Manticoresearch 支持openapi查詢接口,使用search_all_text api接口查詢結(jié)果,查詢體query

9、fastapi實現(xiàn)的Mysql列表字段全文查詢

# main.py
from fastapi import FastAPI
import json
import time
import pymysql

app = FastAPI()

@app.get('/get_mysql/<query>')
async def get_mysql(query):
    conn = pymysql.connect(host="localhost", port=3306, user="root", password="root", database="mydb")
    cursor = conn.cursor()
    fields = "(sname, description, sno,ssex)"

    try:
        create_full_index_sql = f"create fulltext index full_idx_to_table on student{fields} "
        cursor.execute(create_full_index_sql)
    except:
        pass

    query_sql = f"select * from student where match{fields} against('{query}')"
    time_start = time.time()  # 記錄開始時間
    cursor.execute(query_sql)
    time_end = time.time()  # 記錄結(jié)束時間
    results = cursor.fetchall()
    address_list = []
    for row in results:
        address_list.append(row)
    time_sum = time_end - time_start  # 計算的時間差為程序的執(zhí)行時間,單位為秒/s
    address_list.append({"time_sum": time_sum})
    new_json = json.dumps(address_list, ensure_ascii=False)
    return json.loads(new_json)

思路: 先創(chuàng)建需要查找的字段即篩選器,利用篩選器列表創(chuàng)建全文檢索index(full_idx_to_table ) 后,使用fts(Full-Text Search)查詢

10、fastapi實現(xiàn)接口源碼即驗證

  • fastapi源碼
# main.py

from fastapi import FastAPI
from elasticsearch_query_class import elasticsearchself
import json
from manticoreself import manticoresearchself
import time
import pymysql

app = FastAPI()

@app.get("/get_es/{query}")
async def get_es(query):
    fields = ['*']
    es=elasticsearchself(index_name="student")
    time_start = time.time()  # 記錄開始時間
    data=es.search_by_fields(query,fields)
    time_end = time.time()  # 記錄結(jié)束時間
    address_data=data["hits"]["hits"]
    address_list=[]
    for item in address_data:
        address_list.append(item["_source"])
    time_sum = time_end - time_start  # 計算的時間差為程序的執(zhí)行時間,單位為秒/s
    address_list.append({"time_sum":time_sum})
    new_json=json.dumps(address_list,ensure_ascii=False)
    return json.loads(new_json)

@app.get('/get_mc/<query>')
async def get_mc(query):
    mc = manticoresearchself(index_name="student")
    time_start = time.time()  # 記錄開始時間
    data = mc.search_all_text(query)
    time_end = time.time()  # 記錄結(jié)束時間
    address_data = data._hits._hits
    address_list = []
    for item in address_data:
        address_list.append(item["_source"])

    time_sum = time_end - time_start  # 計算的時間差為程序的執(zhí)行時間,單位為秒/s
    address_list.append({"time_sum": time_sum})
    new_json = json.dumps(address_list, ensure_ascii=False)
    return json.loads(new_json)

@app.get('/get_mysql/<query>')
async def get_mysql(query):
    conn = pymysql.connect(host="localhost", port=3306, user="root", password="root", database="mydb")
    cursor = conn.cursor()
    fields = "(sname, description, sno,ssex)"

    try:
        create_full_index_sql = f"create fulltext index full_idx_to_table on student{fields} "
        cursor.execute(create_full_index_sql)
    except:
        pass

    query_sql = f"select * from student where match{fields} against('{query}')"
    time_start = time.time()  # 記錄開始時間
    cursor.execute(query_sql)
    time_end = time.time()  # 記錄結(jié)束時間
    results = cursor.fetchall()
    address_list = []
    for row in results:
        address_list.append(row)
    time_sum = time_end - time_start  # 計算的時間差為程序的執(zhí)行時間,單位為秒/s
    address_list.append({"time_sum": time_sum})
    new_json = json.dumps(address_list, ensure_ascii=False)
    return json.loads(new_json)
  • 驗證(地址:http://127.0.0.1:8000/dcos)

fastapi結(jié)合Manticore Search、elasticsearch、mysql實現(xiàn)全文搜索,fastapi,elasticsearch,mysql

?

fastapi結(jié)合Manticore Search、elasticsearch、mysql實現(xiàn)全文搜索,fastapi,elasticsearch,mysql

?fastapi結(jié)合Manticore Search、elasticsearch、mysql實現(xiàn)全文搜索,fastapi,elasticsearch,mysql

?

10、總結(jié)

  1. elasticsearch 全文搜索
  • 支持中、英全文搜索
  • 但速度沒有mysql和Manticore Search快
  1. Manticore Search全文搜索
  • 暫時只支持英文全文搜索
  • 搜索速度快,相比es少量數(shù)據(jù)快,沒有mysql少量數(shù)據(jù)快,但據(jù)官方顯示大量數(shù)據(jù)時Manticore Search快于mysql
  1. Mysql全文搜索
  • 支持中、英搜索,中文時sql ?against中加IN BOOLEAN MODE
  • 少量數(shù)據(jù)時搜索極快,但全文搜索時需要創(chuàng)建搜索數(shù)據(jù)的全文索引,有些麻煩

到了這里,關(guān)于fastapi結(jié)合Manticore Search、elasticsearch、mysql實現(xiàn)全文搜索的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點(diǎn)擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • elastic search java api 向量搜索實踐 / java結(jié)合es實現(xiàn) 以圖搜圖
  • Elasticsearch實現(xiàn)全文搜索的步驟和實現(xiàn)原理

    Elasticsearch實現(xiàn)全文搜索的步驟和實現(xiàn)原理

    ElasticSearch(簡稱為ES)是一個基于開源的分布式搜索和分析引擎,它提供了強(qiáng)大的全文搜索、結(jié)構(gòu)化查詢、實時數(shù)據(jù)分析和可視化等功能。它是建立在 Apache Lucene 搜索引擎庫之上的,并且通過 RESTful API 提供了簡單易用的接口。 以下是 ElasticSearch 的一些主要特點(diǎn): 分布式架構(gòu)

    2024年02月06日
    瀏覽(26)
  • ElasticSearch 實現(xiàn)分詞全文檢索 - SpringBoot 完整實現(xiàn) Demo

    ElasticSearch 實現(xiàn)分詞全文檢索 - SpringBoot 完整實現(xiàn) Demo

    需求 做一個類似百度的全文搜索功能 搜素自動補(bǔ)全(suggest) 分詞全文搜索 所用的技術(shù)如下: ElasticSearch Kibana 管理界面 IK Analysis 分詞器 SpringBoot 實現(xiàn)流程 可以通過 Canal 對 MySQL binlog 進(jìn)行數(shù)據(jù)同步,或者 flink 或者 SpringBoot 直接往ES里添加數(shù)據(jù) 當(dāng)前以 SpringBoot 直接代碼同

    2024年02月03日
    瀏覽(25)
  • SpringBoot封裝Elasticsearch搜索引擎實現(xiàn)全文檢索

    注:本文實現(xiàn)了Java對Elasticseach的分頁檢索/不分頁檢索的封裝 ES就不用過多介紹了,直接上代碼: 創(chuàng)建Store類(與ES字段對應(yīng),用于接收ES數(shù)據(jù)) Elasticsearch全文檢索接口:不分頁檢索 Elasticsearch全文檢索接口:分頁檢索 本文實現(xiàn)了Java對Elasticsearch搜索引擎全文檢索的封裝 傳入

    2024年02月04日
    瀏覽(38)
  • ElasticSearch+Neo4j+ElasticSearch Head實現(xiàn)全文檢索應(yīng)用

    本文主要闡述利用ES、知識圖譜(Neo4j)實現(xiàn)全文檢索,并利用ElasticSearch Head開源項目進(jìn)行全文檢索測試。實驗在圖譜的幫助下如何開展全文檢索功能,為后續(xù)的復(fù)雜查詢或語義檢索做準(zhǔn)備。 一、運(yùn)行環(huán)境 1.Linux 7.5 2.JDK 1.8.0_191 3.ElasticSearch 7.17.4,注意用ES自帶的jdk,因為這個版

    2024年02月09日
    瀏覽(16)
  • 基于 ElasticSearch 實現(xiàn)站內(nèi)全文搜索,寫得太好了

    基于 ElasticSearch 實現(xiàn)站內(nèi)全文搜索,寫得太好了

    搜索引擎服務(wù)使用ElasticSearch 提供的對外web服務(wù)選則springboot web 1.1 ElasticSearch Elasticsearch是一個基于Lucene的搜索服務(wù)器。它提供了一個分布式多用戶能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java語言開發(fā)的,并作為Apache許可條款下的開放源碼發(fā)布,是一種流行的企

    2024年04月27日
    瀏覽(18)
  • Java調(diào)用Elasticsearch API實現(xiàn)全文檢索,搭配MinIO文件存儲

    Java調(diào)用Elasticsearch API實現(xiàn)全文檢索,搭配MinIO文件存儲

    應(yīng)用背景: 對存儲在MinIO服務(wù)器的文件實現(xiàn)全文檢索。也可以是其他服務(wù)器或本地文件,本文僅詳細(xì)介紹MinIO文件的讀取及轉(zhuǎn)換。通過Elasticsearch的Ingest-Attachment插件抽取文件內(nèi)容,支持Word、Excel、PDF、TXT等格式文件,無需手動解析文件內(nèi)容。 上代碼,詳細(xì)解釋可以閱讀注釋、

    2024年02月11日
    瀏覽(50)
  • FastApi-1-結(jié)合sql 增/查demo

    FastApi-1-結(jié)合sql 增/查demo

    fastapi已經(jīng)學(xué)習(xí)有一段時間,今天抽時間簡單整理下。 官網(wǎng)介紹: FastAPI 是一個用于構(gòu)建 API 的現(xiàn)代、快速(高性能)的 web 框架,使用 Python 3.6+ 并基于標(biāo)準(zhǔn)的 Python 類型提示。 快速:可與 NodeJS 和 Go 并肩的極高性能(歸功于 Starlette 和 Pydantic)最快的 Python web 框架之一。 高效

    2024年02月12日
    瀏覽(15)
  • Mysql 簡單實現(xiàn)全文檢索(FULLTEXT)

    版本支持 MySQL 5.6 以前的版本,只有 MyISAM 存儲引擎支持全文索引; MySQL 5.6 及以后的版本,MyISAM 和 InnoDB 存儲引擎均支持全文索引; 只有字段的數(shù)據(jù)類型為 char、varchar、text 及其系列才可以建全文索引。 按順序操做: 1.修改數(shù)據(jù)庫配置 etc/my.cnf 文件 [mysqld] 下面加入 ngram_token_s

    2024年02月09日
    瀏覽(23)
  • MySQL使用全文檢索實現(xiàn)模糊搜索

    創(chuàng)建全文檢索有兩種方式 方式一: 方法二: in boolean mode(布爾模式): 可以為檢索的字符串增加操作符,且不會像自然語言一樣自動拆詞查詢并集(除非手動空格隔開) 全文檢索模糊查詢使用全文索引來提高搜索效率,可以快速查詢大數(shù)據(jù)量中的模糊匹配結(jié)果。而LIKE模糊查

    2024年02月15日
    瀏覽(19)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包