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);
	}
	
	
	
}






posted on 2016-12-22 11:33  愤怒的苹果ext  阅读(26)  评论(0编辑  收藏  举报

导航