Java中獲取MongoDB連接的方法詳解
更新時間:2019年10月11日 10:04:03 作者:德邦總管
這篇文章主要介紹了Java中獲取MongoDB連接的方法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
首先是所需jar包,Maven中的配置如下:
<dependency> <groupId>org.mongodb</groupId> <artifactId>mongodb-driver</artifactId> <version>3.4.1</version> </dependency> <dependency> <groupId>org.mongodb</groupId> <artifactId>bson</artifactId> <version>3.4.1</version> </dependency> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-mongodb</artifactId> <version>1.7.0.RELEASE</version> </dependency> <dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-java-driver</artifactId> <version>3.9.1</version> </dependency>
獲取連接的代碼如下(本中用的是模板類):
List<ServerAddress> addrs = new ArrayList<ServerAddress>(); addrs.add(new ServerAddress(dataSource.getSourceIp(), Integer.valueOf(dataSource.getSourcePort()))); List<MongoCredential> credentials = new ArrayList<MongoCredential>(); credentials.add(MongoCredential.createScramSha1Credential(dataSource.getUsername(), dataSource.getSourceName(), dataSource.getPassword().toCharArray())); MongoClient mongoClient = new MongoClient(addrs, credentials); MongoDbFactory mongoDbFactory = new SimpleMongoDbFactory(mongoClient, dataSource.getSourceName()); MongoTemplate mongoTemplate = new MongoTemplate(mongoDbFactory); mongoTemplate.getCollectionNames();
或者用如下方式獲取:
ServerAddress serverAddress = new ServerAddress("192.168.16.121",27017);
List<ServerAddress> addrs = new ArrayList<ServerAddress>();
addrs.add(serverAddress);
//MongoCredential.createScramSha1Credential()三個參數(shù)分別為 用戶名 數(shù)據(jù)庫名稱 密碼
MongoCredential credential = MongoCredential.createScramSha1Credential("root", "admin", "123456Ab".toCharArray());
List<MongoCredential> credentials = new ArrayList<MongoCredential>();
credentials.add(credential);
//通過連接認(rèn)證獲取MongoDB連接
MongoClient mongoClient = new MongoClient(addrs,credentials);
//連接到數(shù)據(jù)庫
MongoDatabase mongoDatabase = mongoClient.getDatabase("admin");
mongoDatabase.getCollection("test").find().iterator();
// 關(guān)閉數(shù)據(jù)庫連接
mongoClient.close();
附帶簡單增刪改查的例子:
package test;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import org.junit.Test;
import org.springframework.data.domain.Sort;
import org.springframework.data.mongodb.MongoDbFactory;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.SimpleMongoDbFactory;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;
import com.mongodb.MongoClient;
import com.mongodb.MongoCredential;
import com.mongodb.ServerAddress;
import com.mongodb.WriteResult;
import bean.Book;
import bean.Good;
import bean.ShopDO;
import net.sf.json.JSONObject;
public class MongoTemplateTest {
public static MongoTemplate mongoTemplate = getMongoTemplate();
public static void main(String[] args) {
System.out.println(mongoTemplate.getCollectionNames());
}
public static MongoTemplate getMongoTemplate(){
String host = "192.168.16.121";
int port = 27017;
String databaseName = "test";
String username = "root";
String password = "123456Ab";
//ServerAddress(host,port)兩個參數(shù)分別為 IP地址 端口號
ServerAddress serverAddress = new ServerAddress(host,port);
List<ServerAddress> addrs = new ArrayList<ServerAddress>();
addrs.add(serverAddress);
//MongoCredential.createScramSha1Credential(username,source,password)三個參數(shù)分別為 用戶名 數(shù)據(jù)庫名稱 密碼
MongoCredential credential = MongoCredential.createScramSha1Credential(username, databaseName, password.toCharArray());
List<MongoCredential> credentials = new ArrayList<MongoCredential>();
credentials.add(credential);
//通過連接認(rèn)證獲取MongoDB連接
MongoClient mongoClient = new MongoClient(addrs,credentials);
MongoDbFactory mongoDbFactory = new SimpleMongoDbFactory(mongoClient, databaseName);
MongoTemplate mongoTemplate = new MongoTemplate(mongoDbFactory);
return mongoTemplate;
}
/**
* 插入數(shù)據(jù)
*/
@Test
public void save(){
ShopDO shop1 = new ShopDO(100L,"菜鳥教程");
ShopDO shop2 = new ShopDO(101L,"有道筆記");
mongoTemplate.save(shop1,"col");
mongoTemplate.save(shop2,"col");
System.out.println("mongoDB插入數(shù)據(jù)成功,集合為col,文檔為:"+mongoTemplate.getCollection("col"));
}
@Test
public void save1(){
Book book = new Book(22L,"英語","32.5");
mongoTemplate.save(book,"col");
}
@Test
public void save2(){
Good good = new Good(new HashMap<String,String>(){{put("id","1");put("name","動物");}});
mongoTemplate.save(good,"col");
}
@Test
public void save3(){
mongoTemplate.save(JSONObject.fromObject("{\"這樣\":\"we\",\"好吧\":\"hai\"}"),"col");
System.out.println("mongoDB插入數(shù)據(jù)成功,集合為col,文檔為:"+mongoTemplate.getCollection("col"));
}
/**
* 查詢所有
*/
@Test
public void findAll(){
List<ShopDO> list = mongoTemplate.findAll(ShopDO.class,"col");
System.out.println("mongoDB查詢數(shù)據(jù)成功,集合為col,文檔為:");
for (ShopDO shopDO:list){
System.out.println(shopDO.getNo()+"/"+shopDO.getName());
}
}
/**
* 單條件查詢
*/
@Test
public void simpleQuery(){
Query query = Query.query(Criteria.where("no").is(100L));
List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
System.out.println("mongoDB按條件ID查詢數(shù)據(jù)成功,集合為col,文檔為:");
for (ShopDO shopDO:list){
System.out.println(shopDO.getNo()+"/"+shopDO.getName());
}
}
/**
* 多條件查詢
*/
@Test
public void muchQuery(){
Criteria criteria = new Criteria();
//or是條件或查詢,and是條件與查詢
criteria.orOperator(
Criteria.where("no").is(100),
Criteria.where("name").is("菜鳥教程"));
Query query = new Query(criteria); //組合查詢放入query
Sort sort = new Sort(new Sort.Order(Sort.Direction.DESC,"no")); //結(jié)果集進行排序
query.with(sort);
List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
System.out.println("mongoDB組合查詢數(shù)據(jù)成功,集合為col,文檔為:");
for (ShopDO shopDO:list){
System.out.println(shopDO.getNo()+"/"+shopDO.getName());
}
}
/**
* 分頁查詢
*/
@Test
public void LimitQuery(){
Query query = new Query();
query.skip(1).limit(3);
List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
System.out.println("mongoDB分頁查詢下標(biāo)為1開始總共3行數(shù)據(jù),集合為col,文檔為:");
for (ShopDO shopDO:list){
System.out.println(shopDO.getNo()+"/"+shopDO.getName());
}
}
/**
* 模糊查詢
*/
@Test
public void LikeQuery(){
Query query = new Query(Criteria.where("name").regex("菜鳥"));
List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
System.out.println("mongoDB查詢名稱叫菜鳥的數(shù)據(jù)成功,集合為col,文檔為:");
for (ShopDO shopDO:list){
System.out.println(shopDO.getNo()+"/"+shopDO.getName());
}
Update update = new Update();
update.set("name","菜鳥教程old");
WriteResult wr = mongoTemplate.updateMulti(query,update,"col");
System.out.println("mongoDB更新數(shù)據(jù)成功,集合為col,行數(shù)為:" + wr.getN());
}
/**
* 更新
*/
@Test
public void update(){
Query query = new Query(Criteria.where("no").is(100));
List<ShopDO> list = mongoTemplate.find(query,ShopDO.class,"col");
System.out.println("mongoDB查詢no為100的數(shù)據(jù)成功,集合為col,文檔為:");
for (ShopDO shopDO:list){
System.out.println(shopDO.getNo()+"/"+shopDO.getName());
}
Update update = new Update();
update.set("name","菜鳥教程new");
WriteResult wr = mongoTemplate.updateFirst(query,update,"col");
System.out.println("mongoDB更新數(shù)據(jù)成功,集合為col,行數(shù)為:" + wr.getN());
}
/**
* 刪除
*/
@Test
public void delete(){
Query query = new Query(Criteria.where("no").is(1));
WriteResult result = mongoTemplate.remove(query, "col");
System.out.println("mongoDB刪除數(shù)據(jù)成功,集合為col,行數(shù)為:" + result.getN() + "刪除的ID為"+result.getUpsertedId());
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot WebSocket連接報no mapping for GE
文章描述了一個在調(diào)試WebSocket連接時遇到的`nomappingforGET`異常問題,并提供了問題解決的方法,包括檢查WebSocket注解和補充相關(guān)配置,此外,還特別提到了在使用Nginx轉(zhuǎn)發(fā)WebSocket時所需的配置2025-02-02
spring MVC + bootstrap實現(xiàn)文件上傳示例(帶進度條)
本篇文章主要介紹了spring MVC + bootstrap實現(xiàn)文件上傳示例(帶進度條),非常具有使用價值,有需要的朋友可以了解一下。2017-03-03
使用java8 API遍歷過濾文件目錄及子目錄和隱藏文件示例詳解
這篇文章主要介紹了使用java8API遍歷過濾文件目錄及子目錄及隱藏文件示例詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
Apache Commons Math3學(xué)習(xí)之?dāng)?shù)值積分實例代碼
這篇文章主要介紹了Apache Commons Math3學(xué)習(xí)之?dāng)?shù)值積分實例代碼,涉及使用辛普森積分的例子,這里分享給大家,供需要的朋友參考。2017-10-10
Spring中使用atomikos+druid實現(xiàn)經(jīng)典分布式事務(wù)的方法
這篇文章主要介紹了Spring中使用atomikos+druid實現(xiàn)經(jīng)典分布式事務(wù)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-06-06

