mongoDB2.6,java使用具体解释
本文使用的环境是:win7_64+Eclipse+maven
一、准备工作
下载java驱动包
驱动包下载地址:http://mvnrepository.com/artifact/org.mongodb/mongo-java-driver
mongoDB下载:http://www.mongodb.org/
在线api:http://docs.mongodb.org/manual/applications/drivers/
二、安装Mongo
1.windows下安装方式:
安装Mongo数据库:
第一步:下载安装包:假设是win系统,注意是64位还是32位版本号的,请选择正确的版本号。
第二步:新建文件夹“D:\MongoDB”,解压下载到的安装包,找到bin文件夹以下所有.exe文件。复制到刚创建的文件夹下。
第三步:在“D:\MongoDB”文件夹下新建“data”文件夹。它将会作为数据存放的根文件夹。
配置Mongo服务端:
  打开CMD窗体,依照例如以下方式输入命令:
  > d:
  > cd D:\MongoDB
  > mongod --dbpath D:\MongoDB\data
启动成功后从浏览器訪问:http://localhost:27017/
标明windows下的mongodb已经启动成功。
2.linux安装方式:
下载后解压确保数据库文件夹大小剩余空间在3G以上;
这里採用配置文件方式启动:在mongodb的根文件夹创建一个名为:mongodb.conf的文件。内容例如以下:
#fork=true #以守护进程的方式运行,创建server进程
##master=true #单主从配置时设为主server
##salve=true ##单主从配置时设为从server
#replSet=blort #设置富本集的名字
#shardsvr=true #设置是否分片
#repairpath = /mongodb2.6.3/repair
#pidfilepath = /mongodb2.6.3/mongodb.pid
#sysinfo = true
#verbose = true
#cpu = true
#Network and security set
#Management
#nohttpinterface = true
#rest = true
#syncdelay = 5
#Directory and relavent set
dbpath = /mongodb2.6.3/data #数据库路径
logpath = /mongodb2.6.3/logs/mongodb.log #日志输出文件路径
logappend = true #日志输出方式
directoryperdb = true
noauth = true
port = 8888 #端口号
maxConns = 1024
fork = true
quota = true
quotaFiles = 1024
nssize = 16
启动方式例如以下:/mongodb2.6.3/bin/mongod -f /mongodb2.6.3/mongodb.conf
记得开启linux的訪问端口:
#vi /etc/sysconfig/iptables
yy复制一行
p粘贴
改动端口
#service iptables restart
设置开机自启动
#echo /mongodb2.6.3/bin/mongod -f /mongodb2.6.3/mongodb.config >>/etc/rc.local
数据库启动完毕,接下来是创建数据库和集合:
mongo --port 8888
> show dbs
admin  (empty)
local  0.078GB
> use admin(切换管理用户)
switched to db admin
> db.mymongo(创建数据库)
admin.mymongo
> db.addUser("root","root")(加入用户)
WARNING: The 'addUser' shell helper is DEPRECATED. Please use 'createUser' instead
Successfully added user: { "user" : "root", "roles" : [ "root" ] }
> db.auth("root","root")(加入登陆用户)
1
> db.createCollection("t_users")(加入表)
{ "ok" : 1 }
> show collections(显示表)
system.indexes
system.users
system.version
t_users
> db.t_users.save({age:21})(存储数据)
WriteResult({ "nInserted" : 1 })
> db.t_users.find()(查询所有数据)
{ "_id" : ObjectId("53a2e45e4a674863b4ac5398"), "age" : 21 }
mongodb 删除数据库
use mymongo;
db.dropDatabase();
mongodb删除表
db.t_users.drop();
MongoDB服务停止:
  在linux下大家停止非常多服务都喜欢直接kill -9 PID,可是对于MongoDB假设运行了kill -9 PID。在下次启动时可能提示错误,导致服务无法启动,这个时候能够通过运行:
- rm -f /app/hadoop/db/mongod.lock
 
也即删除指定数据文件夹下的mongod.lock文件就可以。
正常停止方法:
kill  -2 PID
或者
- ./mongo -host ip:port
 
先连接须要停止的服务,然后:
- >use admin
 - >db.shutdownServer();
 
这样也能够正常停止服务。
三、Java操作MongoDB演示样例
1、 建立Test.java,完毕简单的mongoDB数据库操作
try {
			Mongo mg = new MongoClient("192.168.186.129", 8888);
			DB db = mg.getDB("mymongo");
//                      用于推断用户登录
//			if(!db.authenticate("sdap", "sdap123".toCharArray())){
//				方法已经不建议使用
//			}
			Set<String> collectionNames = db.getCollectionNames();
			for (String string : collectionNames) {
				System.out.println(string);
			}
			DBCollection collection2 = db.getCollection("t_users2");
			collection2 = db.getCollection("t_users2");
			CarPasitionObj u = new CarPasitionObj();
			u.setLa(1231d);
			u.setLo(42342d);
			u.setPn("京1aaa");
			u.setTp(12);
			String obj2Json = JsonUtils.getSingletonInstance().obj2Json(u);
			BasicDBObject dbObject1=new BasicDBObject();
			dbObject1.put("key", "123131");
			dbObject1.put("value", obj2Json);
			collection2.save(dbObject1);
			<pre name="code" class="java">			BasicDBObject dbObject=new BasicDBObject();
			dbObject.put("key", "123131");
			DBCursor find = collection2.find(dbObject);
			while (find.hasNext()) {
				DBObject next = find.next();
				String key = (String)next.get("key");
				String json = (String)next.get("value");
				System.out.println(key);
				CarPasitionObj formJson = JsonUtils.getSingletonInstance().formJson(json, CarPasitionObj.class);
				System.out.println(formJson.getPn());
			}
} catch (UnknownHostException e) {
            e.printStackTrace();
            
        }
以下贴上我自己的mongodb的工具类:
/**
 * Project Name:main
 * File Name:MongodbCacheManagerUtil.java
 * Package Name:com.hdsx.taxi.driver.cq.cache
 * Date:2014年4月9日下午12:49:55
 * Copyright (c) 2014, sid Jenkins All Rights Reserved.
 *
 *
*/
package com.hdsx.taxi.driver.cq.mongodb;
import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.List;
import org.apache.log4j.Logger;
import com.hdsx.taxi.driver.cq.module.InitServletModule;
import com.hdsx.taxi.driver.cq.tcp.util.JsonUtils;
import com.mongodb.BasicDBObject;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
import com.mongodb.Mongo;
import com.mongodb.MongoClient;
/**
 * ClassName:MongodbCacheManagerUtil
 * Function: TODO ADD FUNCTION.
 * Reason:	 TODO ADD REASON.
 * Date:     2014年4月9日 下午12:49:55
 * @author   sid
 * @see
 */
public class MongodbManagerUtil {
	private static final Logger logger = Logger.getLogger(MongodbManagerUtil.class);
	private Mongo mg = null;
	private DB db = null;
	private volatile static MongodbManagerUtil singleton = null;
	public static final String KEY = "key";
	public static final String VALUE = "value";
	public static MongodbManagerUtil getSingletonInstance() {
		if (singleton == null) {
			synchronized (MongodbManagerUtil.class) {
				if (singleton == null) {
					singleton = new MongodbManagerUtil();
				}
			}
			singleton = new MongodbManagerUtil();
		}
		return singleton;
	}
	private MongodbManagerUtil() {
		if (logger.isDebugEnabled()) {
			logger.debug("MongodbCacheManagerUtil() - start "); //$NON-NLS-1$
		}
			try {
				mg = new MongoClient("192.168.186.129", 8888);
				db = mg.getDB("mymongo");
			} catch (UnknownHostException e) {
				e.printStackTrace();
			}
		if (logger.isDebugEnabled()) {
			logger.debug("MongodbCacheManagerUtil() - end"); //$NON-NLS-1$
		}
	}
	/**
	 *
	 * getCache:(获取缓存对象).
	 *
	 * @author sid
	 * @param name
	 * @return
	 */
	public DBCollection getCache(String name){
		return this.db.getCollection(name);
	}
	/**
	 *
	 * put:(在指定缓存对象中加入须要缓存的对象).
	 *
	 * @author sid
	 * @param cacheName
	 * @param key
	 * @param value
	 */
    public void put(String cacheName, String key, Object value) {
        DBCollection cache = this.db.getCollection(cacheName);
		String obj2Json = JsonUtils.getSingletonInstance().obj2Json(value);
		BasicDBObject obj = new BasicDBObject();
		obj.put(MongodbManagerUtil.KEY, key);
		obj.put(MongodbManagerUtil.VALUE, obj2Json);
        BasicDBObject basicDBObject = new BasicDBObject(MongodbManagerUtil.KEY, key);
        int size = cache.find(basicDBObject).count();
        if (size==0) {
    		cache.save(obj);
		}else{
    		cache.update(basicDBObject, obj);
		}
    }  
    /**
     *
     * get:(依据key从指定缓存对象中获取对象).
     *
     * @author sid
     * @param cacheName
     * @param key
     * @return
     */
    public <T> T get(String cacheName, String key, Class<T> classOfT) {
        DBCollection cache = this.db.getCollection(cacheName);
        List<DBObject> array = cache.find(new BasicDBObject(MongodbManagerUtil.KEY, key)).toArray();
        if (array == null||array.size()==0) {
			return null;
		}
        DBObject dbObject = array.get(0);
        String json = (String)dbObject.get(MongodbManagerUtil.VALUE);
        return JsonUtils.getSingletonInstance().formJson(json, classOfT);
    }  
    /**
     *
     * remove:(从指定缓存对象中清除对象).
     *
     * @author sid
     * @param cacheName
     * @param key
     */
    public void remove(String cacheName, String key) {
        DBCollection cache = this.db.getCollection(cacheName);
        cache.remove(new BasicDBObject(MongodbManagerUtil.KEY,key));
    }  
    /**
     *
     * getKeys:(获取keys列表).
     *
     * @author sid
     * @param cacheName
     * @return
     */
	public List<String> getKeys(String cacheName){
		List<String> list = new ArrayList<String>();
        DBCollection cache = this.db.getCollection(cacheName);
        DBCursor find = cache.find();
        while (find.hasNext()) {
        	DBObject next = find.next();
        	String key = (String) next.get(MongodbManagerUtil.KEY);
        	list.add(key);
		}
        return list;
    }
	/**
	 *
	 * containsKey:(推断消息是否存在).
	 *
	 * @author sid
	 * @param cacheName
	 * @param key
	 * @return
	 */
	public Boolean containsKey(String cacheName,String key){
        DBCollection cache = this.db.getCollection(cacheName);
        BasicDBObject basicDBObject = new BasicDBObject(MongodbManagerUtil.KEY, key);
        int size = cache.find(basicDBObject).count();
        if (size==0) {
    		return false;
		}else{
			return true;
		}
	}
}
除了save、insert、update;mongodb还有remove等操作
当中find方法能够指定查询条件:
大于等于:$gte
小于等于:$lte
不等于:$ne
demo:users.find(new BasicDBObject("age", new BasicDBObject("$gte", 24)))
mongoDB2.6,java使用具体解释的更多相关文章
- java常用英文解释
		
java常用名词解释: OO: object-oriented ,面向对象 OOP:object-oriented programming,面向对象编程 Author:JCC Object:对象JDK ...
 - Java多线程具体解释
		
Java多线程具体解释 多线程简单介绍 概述 多线程(multithreading).是指从软件或者硬件上实现多个线程并发运行的技术.具有多线程能力的计算机因有硬件支持而可以在同一时间运行多于一个线程 ...
 - Java到底是解释型还是编译型语言
		
Java到底是解释型还是编译型语言? 定义 回答这个问题,我们首先来看下概念: 开发人员编写代码,语言是人类可理解的方式,是具有语义的,然而计算机无法理解和执行,因此需要做一层转换. 解释型语言: 运 ...
 - Java keyword具体解释
		
訪问控制修饰符号 1) private 私有的 private keyword是訪问控制修饰符,能够应用于类.方法或字段(在类中声明的变量). 仅仅能在声明 private(内部)类.方 ...
 - JAVA Calendar具体解释
		
(在文章的最后,将会介绍Date类,假设有兴趣,能够直接翻到最后去阅读) 到底什么是一个 Calendar 呢?中文的翻译就是日历,那我们立马能够想到我们生活中有阳(公)历.阴(农)历之分.它们的差别 ...
 - 微信公众平台java开发具体解释(project代码+解析)
		
说明: 本次的教程主要是对微信公众平台开发人员模式的解说,网络上非常多类似文章,但非常多都让初学微信开发的人一头雾水,所以总结自己的微信开发经验,将微信开发的整个过程系统的列出,并对主要代码进行解说分 ...
 - 用java字节码解释i++和++i(转)
		
这几天抽着一些时间,把Java的class文件结构研究了一下,再后来就想起了这个令人厌烦的问题,想从字节码指令的角度看看,java到底是怎么处理这个的 先看一段java代码 package bishi ...
 - 一个Java例子,解释清楚注解的作用
		
原文出处:码农登陆 写在前面 今天聊的是注解,但其实单纯说注解,注解本身没有任何的作用.简单说和注释没啥区别,而它有作用的原因是:注解解释类,也就是相关对代码进行解释的特定类.一般这些类使用反射是可以 ...
 - java线程具体解释
		
线程与进程的差别 (1)程序是一段静态的代码,进程是程序的一次动态执行过程.它是操作系统资源调度的基本单位.线程是比进程更小的执行单位.一个进程在其执行过程中,能够产生多个线程.所以又称线程为&quo ...
 
随机推荐
- [PHP] 算法-将一个字符串转换成一个整数的PHP实现
			
题目描述 将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一 ...
 - Java win7或 xp下配置JDK环境变量
			
JAVA win7或 xp下配置JDK环境变量 by:授客 QQ:1033553122 1.安装JDK,安装过程中可以自定义安装目录等信息,例如我们选择安装目录为D:\java\jdk1.5.0_08 ...
 - wepy框架须知
			
安装脚手架 . 安装构件工具 npm i wepy-cli -g .创建项目 wepy new 项目名 .实时编译 wepy build --watch 或 npm run dev .使用微信开发者工 ...
 - es6 语法 (数组扩展)
			
{ let arr = Array.of(3, 4, 7, 9, 11); console.log('arr', arr); //[3,4,7,9,11] let empty = Array.of() ...
 - vue从入门到进阶:组件Component详解(六)
			
一.什么是组件? 组件 (Component) 是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功 ...
 - Vue2+VueRouter2+webpack 构建项目实战(一):准备工作
			
环境准备 首先,要开始工作之前,还是需要把环境搭建好.需要的环境是nodejs+npm,当然现在安装node都自带了npm. 在终端下面输入命令node -v会有版本号出来.就说明安装成功了.输入np ...
 - POJ3683 Priest John's Busiest Day(2-SAT)
			
Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 11049 Accepted: 3767 Special Judge ...
 - leaflet 如何绘制圆
			
方法1(根据指定的半径和中心点去绘制圆) var polygon1 = new L.Circle([34, 108], 120000, { color: 'red', //颜色 fillColor: ...
 - 基于Python实现的死链接自动化检测工具
			
基于Python实现的死链接自动化检测工具 by:授客 QQ:1033553122 测试环境: win7 python 3.3.2 chardet 2.3.0 脚本作用: 检测系统中访问异常(请求 ...
 - Charles 抓包手机app
			
最近在测为移动端提供的API, 使用mac系统, 发现fiddler在mac下无法使用, 不知道其他朋友是否遇见过, 只能找替代工具. 先去百度上搜索下载Charles 破解版, 选择Charles是 ...