一、在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() );
}
}
}