一、环境的准备
1、MongoDB已经安装完成
2、java环境准备
(1)jdk:oracle官网:https://www.oracle.com/java/technologies/downloads/
(2)开发工具:
eclipse官网:https://www.eclipse.org/
idea官网:https://www.jetbrains.com.cn/idea/
3、选择MongoDB JDBC驱动
https://mongodb.github.io/mongo-java-driver/(可以下载后放在电脑任意位置,只需要在java工程中导入即可)
mongo-java-driver-3.12.1.jar
二、Java代码实现
1、连接数据库
// 连接本地数据库
MongoClient conn=new MongoClient("127.0.0.1");
// show dbs查看所有的数据库
for(String name:conn.listDatabaseNames()){
System.out.println("dbName:"+name);
}
2、获取数据库
// getDatabase == use database
// 获取名字为dbName的数据库
MongoDatabase db=conn.getDatabase("dbName");
// 查看dbName数据库的所有集合
for(String nameColl:db.listCollectionNames()){
System.out.println("collectionName:"+nameColl);
}
3、创建集合
// 创建集合=db.createCollection()
// 创建一个名字为collectionName的集合
db.createCollection("collectionName");
4、删除集合
// 删除集合=db.collectionname.drop
// 先获取到这个集合collectionName,然后删除
MongoCollection<Document> collection = db.getCollection("collectionName");
collection.drop();
5、获取集合(获取的这个集合,这个集合中放着文档<document>)
// 使用com.mongodb.client.MongoDatabase类的getCollection()方法来获取一个集合的文档=db.collectionName
// 返回值:com.mongodb.client.MongoCollection类
// 放的就是一条一条的集合这个document这个类
MongoCollection<Document> collection = mongoDatabase.getCollection("collectionName");
// 查看文档数
collection.count();
6、插入文档
(1)插入一条文档
// 插入一个文档=insertOne:collection.insertOne(doc);
// 新建一个文档doc
Document doc = new Document();
// 使用put放入键值对
doc.put("name", "zs");
doc.put("age", 25);
// book是一个数组
List<String> books=new ArrayList<String>();
books.add("C");
books.add("Java");
books.add("JS");
doc.put("books", books);
// 插入文档
collection.insertOne(doc);
(2)插入多个文档
// 插入多个文档=insertMany:collection.insertMany(documents);
// 创建两个文档
Document document1 = new Document("name","张三").append( "age",20);
Document document2 = new Document( "name", "李四").append("age", 21);
// 把这两个文档放入documents数组中
List<Document> documents = new ArrayList<Document>();
documents.add(document1);
documents.add(document2);
// 插入多个文档
collection.insertMany(documents);
7、删除文档
// 先创建一个文档
Document docDelete=new Document();
// 在里面添加想要删除的文档的条件
docDelete.append("name", "张三");
collection.deleteMany(docDelete);
8、更新文档
// 先创建一个文档
Document docUpdate=new Document();
// 添加要更新的
docUpdate.append("$set",new Document("email","123456@qq.com"));
// Filters常常用来过滤条件 Filters.eq用于指定等于条件
collection.updateOne(Filters.eq("name","李四"), docUpdate);
collection.updateMany(Filters.eq("name","李四"), docUpdate);
// updateOne更新一条文档;updateMany更新多条文档
9、查询文档
(1)普通查询
// FindIterable查询之后返回文档的类
FindIterable<Document> findIterable = collection.find();
// 使用for each打印出每一条文档
for(Document document:findIterable){
System.out.println(document);
}
(2)按条件查询
// 使用Filters过滤条件
FindIterable<Document> findIterable = collection.find(Filters.eq("name","李四"));
// 使用for each打印出符合条件的文档
for(Document document:findIterable){
System.out.println(document);
}
(3)多条件查询
// 使用Filters.add添加多个条件
// Bson类型
Bson filter=Filters.and(Filters.eq("name","李四"),Filters.eq("age", 25));
FindIterable<Document> findIterable = collection.find(filter);
for(Document document:findIterable){
System.out.println(document);
}
10、游标(使用游标输出文档)
// 先查询文档或者按条件查询
FindIterable<Document> findIterable = collection.find();
// 使用游标
MongoCursor<Document> mongoCursor = findIterable.iterator();
// hasNext()就是判断是否还有下一个 有下一个继续往下走
while(mongoCursor.hasNext()){
Document doc1=mongoCursor.next();
// name age books 都是字段
System.out.println(doc1.get("name")
+"》" +doc1.get("age")
+"》" +doc1.get("books"));
// System.out.println(mongoCursor.next());
}
标签:Java,name,--,mongodb,collection,文档,Filters,new,Document From: https://www.cnblogs.com/hyy-0/p/17421789.html