Java如何操作MongoDB常用API文檔
Java操作MongoDB常用API文檔
1.查詢指定字段
collection.find().projection(fields(include("username","pwd"),excludeId()));//返回username與pwd字段且不返回_id字段
Document doc = new Document().append("_id", 0).append("username",1).append("pwd",1);//指定查詢字段,0為不包含此字段,1為包含此字段
FindIterable<Document> findIterable = collection.find().projection(doc);兩種方法查詢結(jié)果相同,區(qū)別是第一種方法使用了include等函數(shù),需要包含頭文件 import static com.mongodb.client.model.Projections.*;
第二種方法使用Document代替了include等函數(shù),無需包含此頭文件。
2.按條件查詢
Document myDoc = collection.find(and(eq("username","liuchao"),eq("pwd","12345"))).first();
//此方法需包含頭文件import static com.mongodb.client.model.Filters.*;
Document myDoc = collection.find(new Document("username", "liuchao").append("pwd", "12345")).first();
//無需包含上面的頭文件3.對(duì)查詢結(jié)果排序
FindIterable<Document> iterable = collection.find().sort(ascending("title"));//按title升序排列
FindIterable<Document> iterable = collection.find().sort(ascending("title","words"));//按title和words升序排列
FindIterable<Document> iterable = collection.find().sort(descending("title"));//按title降序排列
FindIterable<Document> iterable = collection.find().sort(new Document("time",-1));//按time降序排列4.獲取滿足條件的前n條數(shù)據(jù)
MongoCursor<Document> cursor = collection.find(new Document("username","liuchao")).sort(new Document("time",-1)).limit(n).iterator();
//對(duì)滿足條件username=“l(fā)iuchao”的結(jié)果進(jìn)行降序排列,并獲取前n條數(shù)據(jù)。(n=0獲取全部)Java使用MongoDB數(shù)據(jù)庫(kù)相關(guān)API小記
MongDB數(shù)據(jù)庫(kù)使用
MongoDB數(shù)據(jù)庫(kù)的查詢條件或者說習(xí)慣對(duì)于使用MySQL數(shù)據(jù)庫(kù)的開發(fā)人員不太友好,這里總結(jié)一些API的使用心得。
首先介紹我的使用環(huán)境
1.坐標(biāo)的使用:導(dǎo)入springboot的相關(guān)坐標(biāo)
?? ?<!--MongoDB相關(guān)依賴--> ? ? ? ? <dependency> ? ? ? ? ? ? <groupId>org.springframework.boot</groupId> ? ? ? ? ? ? <artifactId>spring-boot-starter-data-mongodb</artifactId> ? ? ? ? </dependency> ? ? ? ? <dependency> ? ? ? ? ? ? <groupId>org.mongodb</groupId> ? ? ? ? ? ? <artifactId>mongodb-driver-sync</artifactId> ? ? ? ? </dependency>
2.驅(qū)動(dòng)坐標(biāo)及其版本號(hào):spring-boot-starter-data-mongodb 中查到的MongoDB版本號(hào)為3.8.2版(不需要寫上去,這里只是明確引入坐標(biāo)的版本)
? ? <dependency> ? ? ? <groupId>org.mongodb</groupId> ? ? ? <artifactId>mongodb-driver</artifactId> ? ? ? <version>3.8.2</version> ? ? ? <scope>compile</scope> ? ? </dependency>
3.MongoDB數(shù)據(jù)庫(kù)需要的配置,以springboot框架為例,配置文件如下:
文件名:application.properties
#springboot MongoDB配置 spring.data.mongodb.username=用戶名 spring.data.mongodb.password=密碼 spring.data.mongodb.authentication-database=一般是admin spring.data.mongodb.database=數(shù)據(jù)庫(kù)名 spring.data.mongodb.port=端口號(hào),默認(rèn)27017 spring.data.mongodb.host=主機(jī)ip
4.相關(guān)API(以下API都是調(diào)用方法,而非底層源碼)
- a.保存(保存分為save方法和insert方法)
save有添加的作用,也有更新的作用; 取決于存入的id是否在文檔中已經(jīng)存在
save(T t),save(T t,String “數(shù)據(jù)庫(kù)名”);
??? ?@Autowired
? ? private MongoTemplate mongoTemplate;
?? ? /**
? ? ?* save有添加的作用,也有更新的作用; 取決于存入的id是否在文檔中已經(jīng)存在
? ? ?* @param student 學(xué)生對(duì)象
? ? ?*/
?? ? public void saveStudent(Student student)
? ? {
? ? ? ? //返回的結(jié)果是保存的對(duì)象本身, 所以一般不寫
? ? ? ? Student result = mongoTemplate.save(student);
? ? }- b.刪除
?? ?/**
? ? ?* 根據(jù)ObjectId刪除記錄
? ? ?*
? ? ?* @param id ObjectID
? ? ?*/
? ? public void delStudentByObjectId(ObjectId id)
? ? {
? ? ? ? //構(gòu)造查詢條件
? ? ? ? Query query = Query.query(Criteria.where("id").is(id));
? ? ? ? //刪除操作(常用API)
? ? ? ? mongoTemplate.remove(query, Student.class);
? ? }- c.修改
修改作用用到的方法是上面說的save方法
- d.查詢
根據(jù)ObjectId查詢單個(gè)
?? ? /**
? ? ?* 根據(jù)ObjectId查找單條記錄
? ? ?* @param id ObjectId
? ? ?* @return 結(jié)果
? ? ?*/
? ? public Student findStudent(ObjectId id)
? ? {
? ? ? ? Query query = Query.query(Criteria.where("id").is(id));
? ? ? ? //常用API
? ? ? ? Student student = mongoTemplate.findOne(query, Student.class);
? ? ? ? return student;
? ? }查詢所有
??? ?public List<Student> findList()
? ? {
? ? ? ? //第一個(gè)參數(shù)可以理解為查出的結(jié)果應(yīng)該封裝到怎樣的對(duì)象中,第二個(gè)參數(shù)可以理解為表名(也可以不寫)
? ? ? ? return mongoTemplate.findAll(Student.class, "tb_student");
? ? }根據(jù)條件查找
比如查找ObjectId不是1的所有數(shù)據(jù)
?? ?public List<Student> findByCondition()
? ? {
? ? ?? ?//構(gòu)造查詢條件
? ? ? ? Query query=Query.query(Criteria.where("id").ne(1));
? ? ? ? //執(zhí)行查找操作,最后一個(gè)參數(shù)可以省略(在實(shí)體類上已經(jīng)加上了注解,指定了對(duì)應(yīng)的表名也就是document的名字)
? ? ? ? List<Student> list = mongoTemplate.find(query, Student.class, "tb_student");
? ? ? ? return list;
? ? }以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring實(shí)戰(zhàn)之FileSystemResource加載資源文件示例
這篇文章主要介紹了Spring實(shí)戰(zhàn)之FileSystemResource加載資源文件,結(jié)合實(shí)例形式分析了spring FileSystemResource加載xml資源文件的具體實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下2019-12-12
java調(diào)用WebService服務(wù)的四種方法總結(jié)
WebService是一種跨編程語言、跨操作系統(tǒng)平臺(tái)的遠(yuǎn)程調(diào)用技術(shù),已存在很多年了,很多接口也都是通過WebService方式來發(fā)布的,下面這篇文章主要給大家介紹了關(guān)于java調(diào)用WebService服務(wù)的四種方法,需要的朋友可以參考下2021-11-11
Java使用NIO包實(shí)現(xiàn)Socket通信的實(shí)例代碼
本篇文章主要介紹了Java使用NIO包實(shí)現(xiàn)Socket通信的實(shí)例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02
Java關(guān)于桶排序的知識(shí)點(diǎn)總結(jié)
這篇文章給大家總結(jié)了關(guān)于JAVA中J桶排序的相關(guān)知識(shí)點(diǎn)和用法分享,有興趣的讀者跟著學(xué)習(xí)下。2018-04-04
mybatis那些約定的配置你真的都了解嗎(經(jīng)驗(yàn)總結(jié))
mybatsi中Mapper和xml文件之間有很多約定俗稱的規(guī)則,比如名稱匹配,包掃描,別名等,這些規(guī)則是什么。如果想更加靈活,該如何配置呢?今天就給大家講一下如何配置mybatsi的xml文件2021-06-06
使用Java在線生成pdf文檔的代碼實(shí)現(xiàn)
在實(shí)際的業(yè)務(wù)開發(fā)的時(shí)候,研發(fā)人員往往會(huì)碰到很多這樣的一些場(chǎng)景,需要提供相關(guān)的電子憑證信息給用戶,熟悉這塊業(yè)務(wù)的童鞋,一定特別清楚,目前最常用的解決方案通過一些技術(shù)手段生成對(duì)應(yīng)的PDF文件,下面小編給大家詳細(xì)說說2025-04-04
Java使用Runnable接口創(chuàng)建線程的示例代碼
在Java中,多線程編程是實(shí)現(xiàn)并發(fā)操作的重要手段之一,通過多線程,程序可以同時(shí)執(zhí)行多個(gè)任務(wù),從而提高應(yīng)用程序的效率和響應(yīng)速度,Java提供了多種創(chuàng)建線程的方式,其中實(shí)現(xiàn)Runnable接口是最常見且推薦的方式之一,本文將詳細(xì)介紹如何使用Runnable接口創(chuàng)建線程2025-02-02
學(xué)會(huì)Pulsar Consumer的使用方式
這篇文章主要介紹了Pulsar Consumer的使用方式,全文使用大量的代碼來做了詳細(xì)的講解,感興趣的小伙伴可以參考一下這篇文章,希望讀完能對(duì)你有很大的幫助2021-08-08

