MongoDB 字符串值長度條件查詢

在實際項目中常常會有根據字段值長度大小進行限制查詢,例如查詢商品名稱過長或過短的商品信息,具體的實現方式可能有多種,在此記錄常見的兩種實現


  • 使用 $where 查詢(性能稍遜一些)

1
2
3
4
5
//查詢商品名稱長度大于25個字符的商品
db.item.find({item_name:{$exists:true},$where:"(this.item_name.length?>?25)"}).limit(5)
//查詢商品名稱長度小于5個字符的商品
db.item.find({$where:"this.item_name.length?<?5"}).limit(5)


  • 使用正則表達式查詢(性能比$where 高)

1
2
3
4
5
//查詢商品名稱長度大于25個字符的商品
db.item.find({"item_name":?{"$exists":?true,?"$regex":?/^.{25,}$/}}).limit(5)
//查詢商品名稱長度小于5個字符的商品
db.item.find({"item_name":?{"$regex":?/^.{0,5}$/}}).limit(5)


Java 使用 Spring data mongodb:

1
2
3
4
5
String?pattern?=?String.format("^.{%s,}$",?overlength);
Criteria?criteria?=?Criteria.where("item_name").regex(pattern,?"m");
Query?query?=?new?Query(criteria);
mongoTemplate.find(query,?Item.class)


? ?參考地址:https://docs.mongodb.com/manual/reference/operator/query/regex/

????原文轉自:?http://www.xuexiyuan.cn/article/detail/74.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/373542.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/373542.shtml
英文地址,請注明出處:http://en.pswp.cn/news/373542.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

虛擬化Java應用程序:最佳實踐(JavaOne 2011)

賈斯汀穆雷&#xff08;Justin Murray&#xff09;早五分鐘就開始了他的演講[“虛擬化Java應用程序&#xff1a;最佳實踐”&#xff08;21860&#xff09;]&#xff0c;并說虛擬化已經到了人們不再需要擔心利用虛擬化的地步。 他說他的演講大約有一年的歷史&#xff0c;是一個團…

linux里hba狀態_Windows和Linux系統查看HBA卡wwn號的方法 | 系統之家官網

一、windows 系統在windows系統中&#xff0c;可以使用fc hba卡廠家提供的管理軟件查看光纖適配器的wwn號碼&#xff0c;具體如下&#xff1a;qlogic&#xff1a;sansurferemulex&#xff1a;hbanyware二、suse linux 9查看 /proc/scsi/qla2xxx/* &#xff0c;并以 adapter-por…

”二柱子“個人項目

”二柱子“個人項目 關于二柱子的個人項目&#xff0c;據說……是這么發生的…… 二柱子因為懶(,,? ? ?,,)&#xff0c;要給他上小學的兒子編寫個能夠出小學四則運算題目的程序。老師上課的時候又添加了條件&#xff1a; 1、打印至少30道題 2、除了整數之外&#xff0c;還要…

phpstorm9 增加對.vue的支持

1、安裝vue.js插件 2、設置javascript version為ECMAScript 6 3、 <script type"text/ecmascript-6"> </script>轉載于:https://www.cnblogs.com/lobtao/articles/6044378.html

Eclipse中的集成Git插件刪除線上遠程分支

Eclipse 的忠實黨,在使用Git 多人協作以分支的形式開發應用時分支合并到主干后往往再沒什么用(我的做法是保留一兩周再干掉),在此記錄使用Eclipse的Git 插件來刪除無用的分支。 操作步驟: 項目右鍵 — Team — Remote — Push — Next — Finesh 1,下拉框選擇你要刪除的遠程分支…

mysql 查詢系統_使用select和show命令查看mysql數據庫系統信息

(1).select顯示當前日期和時間mysql> select now();---------------------| now() |---------------------| 2019-06-05 13:46:20 |---------------------1 row in set (0.00 sec)顯示當前日期mysql> select curdate();------------| curdate() |------------| 2019-06-0…

從MongoDB GridFS流式傳輸文件

不久前&#xff0c;我在Twitter上發布了自己的最新作品&#xff0c;即從MongoDB GridFS傳輸文件進行下載&#xff08;而不是將整個文件存儲到內存中然后提供服務&#xff09;&#xff0c;這是我取得的一個小勝利。 我答應就此事寫博客&#xff0c;但不幸的是&#xff0c;我的特…

0. 洗好蝦和鍋 1. 放水放老姜&#xff0c;燒開&#xff0c;放鹽 2. 放入蝦&#xff0c;沸騰后&#xff0c;嘗咸淡 3. 放香蔥&#xff0c;乘起來轉載于:https://www.cnblogs.com/gary-tao/p/5248139.html

讀字庫遇到坑爹的問題

轉載請注明出處&#xff1a;http://blog.csdn.net/qq_26093511/article/details/53099262 最近在做一個led顯示屏的項目&#xff0c; 我想顯示 “常”&#xff0c;“州”&#xff0c;“大”&#xff0c;“學”這幾個字&#xff0c;但是只能顯示 “常” 和 “大”&#xff0c;…

如果–否則為編碼風格最佳實踐

下面的帖子將是一個高級花括號討論&#xff0c;沒有對與錯的答案&#xff0c;只是更多的“品味”。 它是關于是否將“ else”&#xff08;以及其他關鍵字&#xff0c;例如“ catch”&#xff0c;“ finally”&#xff09;放在換行符上。 有些人可能會寫 if (something) {doIt(…

MongoDB 去重(distinct)查詢后求總數(count)

在使用MonoDB 做報表匯總經常的有去重統計總數的需求,在此總結一下實現方式: 1, 直接使用distinct 語句查詢, 這種查詢會將所有查詢出來的數據返回給用戶, 然后對查詢出來的結果集求總數(耗內存,耗時一些) var len db.student.distinct("name",{"age" :…

adobe premiere pro cc2015.0已停止工作 解決辦法

adobe premiere pro cc2015.0已停止工作 一直報錯 解決辦法就是&#xff1a; 刪除【我的電腦】- 【我的文檔】下的 Adobe 下的Premiere Pro文件夾 現象就是怎么重新安裝都不管用Premiere 參考路徑 &#xff1a;C:\Users\xxx\Documents\Adobe\Premiere Pro 轉載于:https://…

java mysql 語句解析器_幾種基于Java的SQL解析工具的比較與調用

1、sqlparserhttp://www.sqlparser.com/優點&#xff1a;支持的數據庫最多&#xff0c;除了傳統數據庫外還支持hive和greenplum一類比較新的數據庫&#xff0c;調用比較方便&#xff0c;功能不錯缺點&#xff1a;收費&#xff0c;500$起2、Apache Calcite一個構建JDBC或者ODBC訪…

Css Sprites 多張圖片整合在一張圖片上

CSS Sprites原理&#xff1a; CSS Sprites其實就是把網頁中一些背景圖片整合到一張圖片文件中&#xff0c;再利用CSS的“background-image”&#xff0c;“background- repeat”&#xff0c;“background-position”的組合進行背景定位&#xff0c;background-position可以用數…

MongoDB 分析查詢性能

cursor.explain(“executionStats”)和 db.collection.explain(“executionStats”) 方法提供關于查詢性能的相關信息。這些信息可用于衡量查詢是否使用了索引以及如何使用索引。 db.collection.explain() 還提供有關其他操作的執行信息。例如 db.collection.update()。 有關詳…

無需復雜插件即可從Eclipse啟動和調試Tomcat

像Eclipse這樣的現代IDE提供了各種插件來簡化Web開發。 但是&#xff0c;我相信將Tomcat作為“常規” Java應用程序啟動仍然可以提供最佳的調試體驗。 大多數情況下&#xff0c;這是因為這些工具將Tomcat或任何其他servlet容器作為外部進程啟動&#xff0c;然后在其上附加一個遠…

flutter 國際化_Flutter 開發實戰資源推薦

開工第一天&#xff0c;來點輕松的資源推薦。這是一篇實戰類資源推薦&#xff0c;其實Flutter的入門資料官方已經做得很好了&#xff0c;如果你是零基礎&#xff0c;還是建議先啃一遍官方的教程&#xff0c;然后再看以下實戰資源&#xff0c;相信在你看官方課程中涉及到的一些疑…

2-5-666:放蘋果

描述把M個同樣的蘋果放在N個同樣的盤子里&#xff0c;允許有的盤子空著不放&#xff0c;問共有多少種不同的分法&#xff1f;&#xff08;用K表示&#xff09;5&#xff0c;1&#xff0c;1和1&#xff0c;5&#xff0c;1 是同一種分法。輸入第一行是測試數據的數目t&#xff08…

JSF和“立即”屬性–命令組件

JSF中的即時屬性通常被誤解。 如果您不相信我&#xff0c;請查看Stack Overflow 。 造成這種混亂的部分原因可能是輸入&#xff08;即<h&#xff1a;inputText />&#xff09;和命令&#xff08;即<h&#xff1a;commandButton />&#xff09;組件都立即可用&#…

通過joystick遙感和按鍵控制機器人--11

原創博客&#xff1a;轉載請表明出處&#xff1a;http://www.cnblogs.com/zxouxuewei/ 1.首先安裝joystick遙控器驅動&#xff1a; sudo apt-get install ros-indigo-joystick-drivers ros-indigo-turtlebot-teleop 2.運行tulterbot機器人&#xff1a; roslaunch rbx1_bringup …