首页 文章资讯内容详情

Java操作MongoDB之mongodb-driver(一)

2026-05-31 4 花语

本文内容纲要:

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