mongodb基本使用
mongodb是一个文档型的NOSQL数据库,官网下载地址https://www.mongodb.com/download
linux版本的要64位的我的虚拟机是32位的,我下的是Windows版本,不过操作都差不多。
下载好了接下来就安装。
安装后创建一个数据库路径
cmd运行mongodb服务端
D:\software\mongodbServer\bin/mongod.exe --dbpath D:\software/mongodbData #服务端
再启动一个cmd窗口运行客户端
D:\software\mongodbServer\bin/mongo #客户端
创建db
use dbxx
查询全部db
show dbs
删除db
use runoob
db.dropDatabase()
插入文档
db.col.insert({title: 'test',
description: 'MongoDB 是一个 Nosql 数据库',
by: 'test',
url: 'http://www.test.com',
tags: ['mongodb', 'database', 'NoSQL'],
likes: 200
})
查看文档
db.col.find();
java api 操作 mongodb数据库
需要一个mongo-java-driver的jar 如果你是maven进入这个地址http://mongodb.github.io/mongo-java-driver/
package com.zit.test;
import java.util.ArrayList;
import java.util.List;
import org.bson.Document;
import com.mongodb.MongoClient;
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 MongoDBUtils {
/**
* <p>方法描述:建立连接 </p>
*/
public static MongoDatabase getMongodbConnection() {
try{
// 连接到 mongodb 服务
MongoClient mongoClient = new MongoClient( "127.0.0.1" , 27017 );
// 连接到数据库
MongoDatabase mongoDatabase = mongoClient.getDatabase("zzqtest");
System.out.println("Connect to database successfully");
return mongoDatabase;
}catch(Exception e){
System.err.println( e.getClass().getName() + ": " + e.getMessage() );
return null;
}
}
/**
* <p>方法描述: 创建集合</p>
*/
private static void createCollection (String collectionName) {
getMongodbConnection().createCollection(collectionName);
System.out.println("集合创建成功");
}
/**
* <p>方法描述: 选择集合</p>
*/
private static MongoCollection selectCollection (String collectionName) {
MongoCollection<Document> collection = getMongodbConnection().getCollection(collectionName);
System.out.println("集合选择"+collectionName +"成功");
return collection;
}
/**
* <p>方法描述: 插入文档</p>
*/
private static void insertDocument (MongoCollection<Document> collection) {
Document document2 = new Document("title", "MongoDB");
Document document = new Document("title", "MongoDB").
append("description", document2).
append("likes", 100).
append("by", "Fly");
List<Document> documents = new ArrayList<Document>();
documents.add(document);
collection.insertMany(documents);
System.out.println("文档插入成功");
}
/**
* <p>方法描述:文档更新 </p>
*/
private static void updateDocument (MongoCollection<Document> collection) {
collection.updateMany(Filters.eq("likes", 100), new Document("$set",new Document("likes",200)));
System.out.println("文档更新成功");
}
/**
* <p>方法描述:查询文档 </p>
*/
private static void selectDocument (MongoCollection<Document> collection) {
//检索查看结果
FindIterable<Document> findIterable = collection.find();
MongoCursor<Document> mongoCursor = findIterable.iterator();
while(mongoCursor.hasNext()){
System.out.println(mongoCursor.next());
}
}
/**
* <p>方法描述:删除文档 </p>
*/
private static void deleteDocument (MongoCollection<Document> collection) {
//删除符合条件的第一个文档
collection.deleteOne(Filters.eq("likes", 100));
//删除所有符合条件的文档
collection.deleteMany (Filters.eq("likes", 100));
}
public static void main(String[] args) {
//createCollection("test");
MongoCollection<Document> collection = selectCollection("test");
/*insertDocument(collection);*/
updateDocument(collection);
//deleteDocument(collection);
selectDocument(collection);
}
}