Java 操作mongodb的增删改查操作
MongoDb 非关系型数据库,又称为NoSql(不仅仅是sql),主要是非关系型,分布式,不提供ACID的数据库设计模式。
MongoDB是一种面向文档的数据库管理系统,支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言。
1.需要引入的mongo包
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
<dependency>
<groupId>org.mongodb</groupId>
<artifactId>mongo-java-driver</artifactId>
</dependency>
2.链接mongo的方式
通过URI初始化:
mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
public static void main(String[] args) {
//mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
String url = "设置的mongouri信息";
System.out.println(url);
MongoClientURI uri = new MongoClientURI(url);
MongoClient mongoClient = new MongoClient(uri);
System.out.println(mongoClient);
//获取库对象
MongoDatabase db = mongoClient.getDatabase("数据库名");
MongoCollection<Document> collection = db.getCollection("需要查询的集合名字");
FindIterable doc = collection.find(new Document().append("集合中的字段", "字段值"));
Iterator iterator = doc.iterator();
while (iterator.hasNext()) {
Document result = (Document) iterator.next();
// System.out.println(JSON.toJSONString(result));
Object name = result.get("name");
Object text = result.get("text");
System.out.println("aaaa:"+name);
System.out.println("hhhhh:"+text);
}
//关闭链接
mongoClient.close();
}
通过ip端口
MongoClient mongoClient = new MongoClient(ip, 端口);
3.增删改查
新增操作
//插入数据 Document doc= new Document(); collection.insertOne(doc); //批量插入 List<Document> list = new ArrayList<Document>(); list.add(doc); collection.insertMany(list);
删除操作。单独删除,批量删除
String instanceCollectionName = "集合名";
MongoCollection<Document> instanceCollection = mongoTemplate.getCollection(instanceCollectionName);
//申明删除条件
Bson filter = Filters.eq("code", "123");
//删除与筛选器匹配的单个文档
instanceCollection.deleteOne(filter);
//删除表单实例快照
MongoCollection<Document> newColl= mongoTemplate.getCollection("集合名");
//申明删除条件
Bson historyFilter = Filters.eq("code", "123");
//删除与筛选器匹配的所有文档
newColl.deleteMany(historyFilter);
更新操作,单独更新,批量更新
"$set"修饰符
“$set” 用来设置一个字段的值。如果这个字段不存在,则创建该字段。这对于更新模式或添加用户定义的键来说非常方便。
更新单个字段updateOne
UpdateResult updateOne = currcollection.updateOne(
condition, new Document("$set",new Document("test", "123")),
new UpdateOptions().upsert(true));
更新整个updateMany
currcollection.updateMany(condition, new Document("$set",document));
查询
List<Bson> filters = new ArrayList<>();
// objectCode条件
filters.add(Filters.eq("code","123"));
Bson condition = Filters.and(filters);
FindIterable<Document> doc = collection.find(condition);
参考:https://blog.csdn.net/m0_65004039/article/details/127058581
https://blog.csdn.net/m0_46420244/article/details/125828629

浙公网安备 33010602011771号