java操作mongodb数据库

一、在pom.xml中添加mongo驱动

<dependency>
	<groupId>org.mongodb</groupId>
	<artifactId>mongo-java-driver</artifactId>
	<version>3.2.2</version>
</dependency>

二、CURD

package com.bjx.service;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

import org.bson.Document;

import com.mongodb.BasicDBObject;
import com.mongodb.MongoClient;
import com.mongodb.MongoCredential;
import com.mongodb.ServerAddress;
import com.mongodb.client.FindIterable;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.model.Filters;

public class MongoCon {
	
	//	不同的版本api有所不同,具体参考:https://api.mongodb.com/java/ 该版本 3.2.22
	private static MongoDatabase mongoDatabase;
	static {
		try{
            //ServerAddress()两个参数分别为 服务器地址 和 端口
            ServerAddress serverAddress = new ServerAddress("127.0.0.1",27017);
            System.out.println(serverAddress);
            //MongoCredential.createScramSha1Credential()三个参数分别为 用户名 数据库名称 密码
            MongoCredential credential = MongoCredential.createScramSha1Credential("test", "test", "test".toCharArray());
            //通过连接认证获取MongoDB连接
            MongoClient mongoClient = new MongoClient(Arrays.asList(serverAddress), Arrays.asList(credential));
            //连接到数据库
            mongoDatabase = mongoClient.getDatabase("test");
            System.out.println("<______________Mongodb数据库连接成功!_____________>");
        }catch(Exception e){
            System.err.println("!!MongoDB数据库连接异常:" + e.getMessage() );
        }
	}
	
		//创建集合
	    public static void create(){
	        try{
	        	mongoDatabase.createCollection("usertest");
	            System.out.println("集合创建成功");
	        }catch(Exception e){
	            System.err.println( "!!集合创建异常:" + e.getMessage() );
	        }
	    }
	  //查看数据
	    public static void find(){
	        try {
	            MongoCollection<Document> list = mongoDatabase.getCollection("usertest");
	            BasicDBObject o = new BasicDBObject();
	            o.put("address","深圳市福田区");
	            FindIterable<Document> findIterable = list.find(o);
	            MongoCursor<Document> mongoCursor = findIterable.iterator();
	            while (mongoCursor.hasNext()) {
	                System.out.println("查询的数据:" + mongoCursor.next());
	            }
	        }catch(Exception e){
	            System.err.println( "!!数据查询异常:" + e.getMessage() );
	        }
	 
	    }
	  //新增数据
	    public static void add() {
	        try {
	        	System.out.println(mongoDatabase);
	            //新增两个学生和教师的数据
	            MongoCollection<Document> collections = mongoDatabase.getCollection("usertest");
	            Document document1 = new Document("username", "老师");
	            List<Document> documents = new ArrayList<Document>();
	            documents.add(document1);
	            collections.insertMany(documents);
	            System.out.println("数据插入成功");
	        }catch(Exception e){
	        System.err.println( "!!数据新增异常:" + e.getMessage() );
	    }
	    }
	 
	  //修改数据
	    public static void  update(){
	        try {
	            MongoCollection<Document> mongoCollection = mongoDatabase.getCollection("usertest");
	            //修改满足条件的第一条数据
	            mongoCollection.updateOne(Filters.eq("username", "老师"), new Document("$set", new Document("address", "深圳市福田区")));
	            //修改所以满足条件的数据
	            //mongoCollection.updateMany(Filters.eq("name", "老师"), new Document("$set", new Document("likeTv", "CCTV-1")));
	            FindIterable<Document> findIterable = mongoCollection.find();
	            MongoCursor<Document> mongoCursor = findIterable.iterator();
	            while (mongoCursor.hasNext()) {
	                System.out.println("更新后的数据:" + mongoCursor.next());
	            }
	        }catch(Exception e){
	            System.err.println( "!!数据更新异常:" + e.getMessage() );
	        }
	    }
	  //删除数据
	    public static void delete(){
	        try {
	            MongoCollection<Document> collection = mongoDatabase.getCollection("usertest");
	            //删除符合条件的第一个文档
	            collection.deleteOne(Filters.eq("name", "学生"));
	            //删除所有符合条件的文档
	            //collection.deleteMany(Filters.eq("name", "学生"));
	            //检索查看结果
	            FindIterable<Document> findIterable = collection.find();
	            MongoCursor<Document> mongoCursor = findIterable.iterator();
	            while (mongoCursor.hasNext()) {
	                System.out.println("删除后的数据:" + mongoCursor.next());
	            }
	        }catch(Exception e){
	            System.err.println( "!!数据删除异常:" + e.getMessage() );
	        }
	    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值