Java操作MongoDB之mongodb-driver(一)
本文内容纲要:
- mongodb-driver是mongo官方推出的java连接mongoDB的驱动包,相当于JDBC驱动。
(1)通过maven仓库导入:https://mvnrepository.com/artifact/org.mongodb/mongodb-driver
(2)官网中下载相应的java的驱动:http://docs.mongodb.org/ecosystem/drivers/java/
(3)不同的驱动使用的jar也不相同参考:http://mongodb.github.io/mongo-java-driver/
例如:
<dependencies>
<dependency>
<groupId>org.mongodb</groupId>
<artifactId>mongodb-driver-sync</artifactId>
<version>3.11.2</version>
</dependency>
</dependencies>
2.1查询全部,遍历打印
packagemongodb.test;
importorg.bson.Document;
importcom.mongodb.BasicDBObject;
importcom.mongodb.MongoClient;
importcom.mongodb.client.FindIterable;
importcom.mongodb.client.MongoCollection;
importcom.mongodb.client.MongoDatabase;
publicclassMongodb{
/**
*查询打印全部集合
*/
publicstaticvoidmongoQueryAll(){
//1.创建链接
MongoClientclient=newMongoClient("localhost");
//2.打开数据库test
MongoDatabasedb=client.getDatabase("test");
//3.获取集合
MongoCollection<Document>collection=db.getCollection("stu");
//4.查询获取文档集合
FindIterable<Document>documents=collection.find();
//5.循环遍历
for(Documentdocument:documents){
System.out.println(document);
}
//6.关闭连接
client.close();
}
publicstaticvoidmain(String[]args){
mongoQueryAll();
}
//打印输出stu全部数据
Document{{_id=5d7374e836a89c5a3d18b87a,name=xiaohua}}
Document{{_id=2.0,sn=002,name=xiaogang}}
Document{{_id=3.0,sn=003,name=zhangfei,job=前锋战将}}
Document{{_id=5d73782736a89c5a3d18b87b,sn=004,name=xiaobingbing}}
Document{{_id=5d7396b44ec120618b2dd0cb,name=Document{{surname=李,name=世名}},job=[皇帝,大人物,大丈夫,功成名就]}}
2.2条件查询
/**
*条件查询:如查询id为xxxx的学生所有信息
*/
publicstaticvoidmongoConditionQuery(){
//1.创建链接
MongoClientclient=newMongoClient("localhost");
//2.打开数据库test
MongoDatabasedb=client.getDatabase("test");
//3.获取集合
MongoCollection<Document>collection=db.getCollection("stu");
//4.构建查询条件,按照name来查询
BasicDBObjectstu=newBasicDBObject("name","zhangfei");
//5.通过id查询记录,获取文档集合
FindIterable<Document>documents=collection.find(stu);
//5.打印信息
for(Documentdocument:documents){
System.out.println("name:"+document.getString("name"));
System.out.println("sn:"+document.getString("sn"));
System.out.println("job:"+document.getString("job"));
}
//6.关闭连接
client.close();
}
publicstaticvoidmain(String[]args){
mongoConditionQuery();
}
//执行输出
name:zhangfei
sn:003
job:前锋战将
注意:当需要查询条件+判断的时候这样写,例如查询学号sn>003的学员
//查询sum大于3的学员
BasicDBObjectstu=newBasicDBObject("sum",newBasicDBObject("$gt",003));
2.3插入语句
/**
*插入语句
*/
publicstaticvoidmongoInsert(){
//1.创建链接
MongoClientclient=newMongoClient("localhost");
//2.打开数据库test
MongoDatabasedb=client.getDatabase("test");
//3.获取集合
MongoCollection<Document>collection=db.getCollection("stu");
//4.准备插入数据
HashMap<String,Object>map=newHashMap<String,Object>();
map.put("sn","005");
map.put("name","xiaoA");
map.put("job","A工作");
map.put("sum",6);
//5.将map转换成document
Documentdocument=newDocument(map);
collection.insertOne(document);
//6.关闭连接
client.close();
}
//测试执行
publicstaticvoidmain(String[]args){
mongoInsert();
}
批量插入,仅供参考:
//当需要插入多条文档的时候,循环进行单条插入当然是可以,但是效率不高,MongoDB提供了批量插入的方法
List<DBObject>objs=newArrayList<DBObject>();
objs.add(newBasicDBObject("name","user29").append("age",30).append("sex",1));
objs.add(newBasicDBObject("name","user30").append("age",30).append("sex",1));
collection.insert(objs);
//这样就批量进行了插入。批量插入通过一次请求将数据传递给数据库,然后由数据库进行插入,比循环单条插入节省了每次进行请求的资源。
学习后总结,不足之处请指出,后续修改!
本文内容总结:
原文链接:https://www.cnblogs.com/xiaozhaoboke/p/11880821.html