一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - MongoDB - mongo中模糊查詢的綜合應用

mongo中模糊查詢的綜合應用

2020-05-22 17:53迎風而來 MongoDB

這篇文章主要給大家介紹了關于mongo中模糊查詢的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用mongodb具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

前言

以下是一個mongo查詢的綜合應用,即介紹一個生產中實際應用的模糊查詢,當然其實也很簡單,主要用到mongo中的模糊查詢和$or查詢,以及并的關系,下面是一個mongo中的一條記錄

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
{
 "_id" : "ffe6a068-9043-4334-97d2-75387340e655",
 "file_id" : "ffe6a068-9043-4334-97d2-75387340e655",
 "name" : "中國正大",
 "update_time" : NumberInt(1554975642),
 "create_time" : NumberInt(1554975642),
 "content" : "中國正大相關信息",
 "file_url" : "",
 "file_type" : "",
 "user_ids" : [
 1.0,
 10.0
 ],
 "group_ids" : [
 
 ],
 "is_common" : NumberInt(0),
 "confidence" : -1.0,
 "obj_id" : "",
 "source" : "",
 "content_time" : "",
 "author" : "",
 "summary" : "",
 "info_type" : "00",
 "sub_info_type" : "",
 "title" : "",
 "word_num" : NumberInt(8)
}

對上面一條記錄或者更多條記錄我們生產中的需求是:查詢出集合中(mongo中的集合即是mysql中的表),name或content中包含"正大"二字的記錄(關鍵詞即是用戶隨機輸入的,其實是一個變量),并且時間戳的值大于某一個開始時間和某一個結束時間(這個也是用戶在前端進行選擇,然后我們拿到前端的請求來進行查詢的),并且文件的類型即info_type字段的值為"00",“00”代表的是word也是前端用戶選擇后我們獲取的條件之一,當然還有其他條件想進行嘗試可以自由發揮

下面就是使用mongo語句進行實現的上面的需求:

?
1
db.getCollection("subscribe_test").find({$or:[{"name":{"$regex":"正大"}},{"content":{"$regex":"正大"}}],"update_time":{$gte:1,$lte:2000000000},info_type:"00"})

對于查詢我們有的時候會選擇在程序中進行,有的小伙伴會問上面的mongo語句怎么在編程語言中進行實現,下面是用python語言中進行實現的,我們會引用python中操作mongo的一個模塊即pymongo模塊可以使用pip install pymongo在控制臺或cmd中進行一鍵安裝,至于如何使用也很簡單,可以自行百度或者訪問我的另一篇博客:pymono的簡單使用,下面附上用python代碼實現上面需求的業務代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
import pymongo
import re
# 創建數據庫連接
client = pymongo.MongoClient(host='127.0.0.1', port=8014) #填寫自己本機數據庫的ip和port或者遠程服務器數據庫的ip和port
# 指定數據庫db1,沒有則創建數據庫db1
db = client.dataretrieve
#指定數據庫中指定的表
collection=db.subscribe_test
 
"""1、對表中的數據進行查詢"""
"""
db.collection.find(query, projection)
query :可選,使用查詢操作符指定查詢條件
projection :可選,使用投影操作符指定返回的鍵。查詢時返回文檔中所有鍵值, 只需省略該參數即可(默認省略)。
"""
query = {}
query["$or"] = [
 {"name": re.compile("正大")},
 {"content": re.compile("正大")},
]
query["file_type"] = "00"
query["update_time"] = {"$gte": 0,"$lte": 2000000000}
row=collection.find(filter=query)
for r in row:
 print(r["content"])

下面是生產中實際的開發代碼,只供參考,只是把上面的一些常量,換成了從前端請求的數據:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
def person_handler(req_params, page_size, search_offset):
 """
 去mongo中查詢個人數據
 :param req_params:
 :param page_size:
 :param search_offset:
 :return:
 """
 results = []
 query = {}
 update_time = {}
 if 'start_time' in req_params and req_params["start_time"]:
 start_time = int(req_params["start_time"])
 update_time['$gte'] = start_time
 if 'end_time' in req_params and req_params['end_time']:
 end_time = int(req_params["end_time"])
 update_time['$lte'] = end_time
 if update_time:
 query["update_time"] = update_time
 if 'file_type' in req_params and req_params['file_type']:
 query["file_type"] = req_params["file_type"]
 if 'user_ids' in req_params and req_params['user_ids']:
 query['user_ids'] = int(req_params['user_id'])
 serch_keywords = req_params["search_keywords"]
 
 query["$or"] = [
 {"name": re.compile(serch_keywords)},
 {"content": re.compile(serch_keywords)},
 ]
 print(query)
 result = person_mongodao.search(filter=query).skip(search_offset).limit(page_size)
 count = person_mongodao.search(filter=query).skip(search_offset).limit(page_size).count()
 for row in result:
 results.append(row)
 additions = {"word_segs": req_params["search_keywords"], "remind": 0}
 print("查詢結果", results)
 return results, additions, count

如果有小伙伴說我用的不是python語言譬如java用代碼怎么實現呢?那么如果你會寫mysql來實現上面的需求的話本博主可以推薦你使用mongo的一款可視化工具Studio 3T來將mysql語句轉換成mongo語句,python語句,java語句等

mongo中模糊查詢的綜合應用

mysql語句也類似mongo語句有一個控制臺可以來進行書寫mysql語句,然后進行查詢之后將結果進行轉換

mongo中模糊查詢的綜合應用

總結

以上就是關于mongo模糊查詢的簡單使用,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對服務器之家的支持。

原文鏈接:http://www.cnblogs.com/sui776265233/p/10694958.html

延伸 · 閱讀

精彩推薦
  • MongoDB遷移sqlserver數據到MongoDb的方法

    遷移sqlserver數據到MongoDb的方法

    這篇文章主要介紹了遷移sqlserver數據到MongoDb的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下...

    聽楓xl9682021-01-03
  • MongoDBMongoDB憑什么躋身數據庫排行前五

    MongoDB憑什么躋身數據庫排行前五

    MongoDB以比去年同期超出65.96分的成績繼續雄踞榜單前五,這個增幅在全榜僅次于PostgreSQL的77.99,而其相對于4月份的6.10分的增長也是僅次于微軟SQL Server排名...

    孫浩峰3892020-05-22
  • MongoDBMongodb實現定時備份與恢復的方法教程

    Mongodb實現定時備份與恢復的方法教程

    這篇文章主要給大家介紹了Mongodb實現定時備份與恢復的方法教程,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面...

    chenjsh364522020-05-13
  • MongoDBMongoDB安裝圖文教程

    MongoDB安裝圖文教程

    這篇文章主要為大家詳細介紹了MongoDB安裝圖文教程,分為兩大部分為大家介紹下載MongoDB和安裝MongoDB的方法,感興趣的小伙伴們可以參考一下 ...

    Yangyi.He6132020-05-07
  • MongoDBMongoDB中javascript腳本編程簡介和入門實例

    MongoDB中javascript腳本編程簡介和入門實例

    作為一個數據庫,MongoDB有一個很大的優勢——它使用js管理數據庫,所以也能夠使用js腳本進行復雜的管理——這種方法非常靈活 ...

    MongoDB教程網6982020-04-24
  • MongoDB分布式文檔存儲數據庫之MongoDB分片集群的問題

    分布式文檔存儲數據庫之MongoDB分片集群的問題

    這篇文章主要介紹了分布式文檔存儲數據庫之MongoDB分片集群的問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋...

    Linux-18743072020-12-20
  • MongoDBMongoDB 內存使用情況分析

    MongoDB 內存使用情況分析

    都說 MongoDB 是個內存大戶,但是怎么知道它到底用了多少內存呢...

    MongoDB教程網10002020-09-29
  • MongoDBmongodb基本命令實例小結

    mongodb基本命令實例小結

    這篇文章主要介紹了mongodb基本命令,結合實例形式總結分析了MongoDB數據庫切換、查看、刪除、查詢等基本命令用法與操作注意事項,需要的朋友可以參考下...

    dawn-liu3652020-05-26
主站蜘蛛池模板: 国产日韩一区二区 | 动漫美女人物被黄漫在线看 | yellow视频免费观看播放 | 日本高清在线看 | 女医学护士一级毛片 | 成人精品亚洲人成在线 | 亚洲成人免费 | 久久久久国产一级毛片高清片 | 精品一区二区三区高清免费观看 | spank日本网站脱裤子打屁股 | 日韩大片免费看 | 欧美视频一区二区三区在线观看 | 国产精品一二区 | 欧美成人二区 | 国产精品嫩草影院一二三区入口 | 亚洲国产天堂在线观看 | www.色.con| 亚洲一卡2卡三卡4卡5卡组 | 日韩制服丝袜在线观看 | 青青色在线 | 大学生特黄特色大片免费播放 | 调教人妖| 午夜欧美福利视频 | chaopeng在线观看 | 99热自拍 | 王淑兰与铁柱全文免费阅读 | 欧美激情影音先锋 | 倩女还魂在线观看完整版免费 | 69人成网站色www | 亚洲第一网色综合久久 | 楚乔传第二部免费观看全集完整版 | 百合文高h | 胸奶好大好紧好湿好爽 | jzzjzz视频免费播放 | 精品老司机在线视频香蕉 | 国产高清自拍视频 | 阿 好深 快点 老师受不了 | 国产成人啪精品午夜在线播放 | 欧美xxxxx九色视频免费观看 | 99久久免费国产香蕉麻豆 | 久久永久影院免费 |