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 #以守护进程的方式运行,创建服务器进程

##master=true #单主从配置时设为主服务器

##salve=true ##单主从配置时设为从服务器

#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,在下次启动时可能提示错误,导致服务无法启动,这个时候可以通过执行:

Java代码

  1. rm -f /app/hadoop/db/mongod.lock

也即删除指定数据目录下的mongod.lock文件即可。

正常停止方法:

kill  -2 PID

或者

Java代码

  1. ./mongo -host ip:port

先连接需要停止的服务,然后:

Java代码

  1. >use  admin
  2. >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使用详解,布布扣,bubuko.com

时间: 2024-10-04 00:04:22

mongoDB2.6,java使用详解的相关文章

package-info.java文件详解

package-info.java文件详解 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs 一.pacakge-info.java介绍 pacakge-info.java是一个Java文件,可以添加到任何的Java源码包中.pacakge-info.java的目标是提供一个包级的文档说明或者是包级的注释. pacakge-info.java文件中,唯一要求包含的内容是包的声明语句,比如: package com.ch.service; 二.包文档 在

java 反射 详解

本文来自:blog.csdn.net/ljphhj JAVA反射机制:   通俗地说,反射机制就是可以把一个类,类的成员(函数,属性),当成一个对象来操作,希望读者能理解,也就是说,类,类的成员,我们在运行的时候还可以动态地去操作他们. 理论的东东太多也没用,下面我们看看实践 Demo - Demo: package cn.lee.demo; import java.lang.reflect.Constructor; import java.lang.reflect.Field; import

Java synchronized详解

Java synchronized详解 第一篇: 使用synchronized 在编写一个类时,如果该类中的代码可能运行于多线程环境下,那么就要考虑同步的问题.在Java中内置了语言级的同步原语--synchronized,这也大大简化了Java中多线程同步的使用.我们首先编写一个非常简单的多线程的程序,是模拟银行中的多个线程同时对同一个储蓄账户进行存款.取款操作的. 在程序中我们使用了一个简化版本的Account类,代表了一个银行账户的信息.在主程序中我们首先生成了1000个线程,然后启动它们

Java虚拟机详解——JVM常见问题总结

[正文] 声明:本文只是做一个总结,有关jvm的详细知识可以参考之前的系列文章,尤其是那篇:Java虚拟机详解04--GC算法和种类.那篇文章和本文是面试时的重点. 面试必问关键词:JVM垃圾回收.类加载机制. 先把本文的目录画一个思维导图:(图的源文件在本文末尾) 一.Java引用的四种状态: 强引用:  用的最广.我们平时写代码时,new一个Object存放在堆内存,然后用一个引用指向它,这就是强引用. * 如果一个对象具有强引用,那垃圾回收器绝不会回收它*.当内存空间不足,Java虚拟机宁

Java引用类型详解

JVM  的垃圾回收器对于不同类型的引用有不同的处理方式.java中对于一个对象来说,只要有引用的存在,它就会一直存在于内存中.如果这样的对象越来越多,超出了JVM中的内存总数,JVM就会抛出OutOfMemory错误.虽然垃圾回收的具体运行是由JVM来控制的,但是开发人员仍然可以在一定程度上与垃圾回收器进行交互,其目的在于更好的帮助垃圾回收器管理好应用的内存.这种交互方式就是使用JDK1.2 引入的  java.lang.ref包. 强引用(strong reference) 在一般的 Jav

Java堆栈详解 .

1. Java中堆栈(stack)和堆(heap) (1)内存分配的策略 按照编译原理的观点,程序运行时的内存分配有三种策略,分别是静态的,栈式的,和堆式的. 静态存储分配是指在编译时就能确定每个数据目标在运行时刻的存储空间需求,因而在编译时就可以给他们分配固定的内存空间.这种分配策略要求程序代码中不 允许有可变数据结构(比如可变数组)的存在,也不允许有嵌套或者递归的结构出现,因为它们都会导致编译程序无法计算准确的存储空间需求.栈式存储分配也可称为动态存储分配,是由一个类似于堆栈的运行栈来实现的

Java网络详解

Java网络详解 Java网络基本概念 网络基础知识 1.计算机网络形式多样,内容繁杂.网络上的计算机要互相通信,必须遵循一定的协议.目前使用最广泛的网络协议是Internet上所使用的TCP/IP协议 2.网络编程的目的就是指直接或间接地通过网络协议与其他计算机进行通讯.网络编程中有两个主要的问题,一个是如何准确的定位网络上一台或多台主机,另一个就是找到主机后如何可靠高效的进行数据传输.在TCP/IP协议中IP层主要负责网络主机的定位,数据传输的路由,由IP地址可以唯一地确定Internet上

Java面向对象详解

Java面向对象详解 前言:接触项目开发也有很长一段时间了,最近开始萌发出想回过头来写写以前学 过的基础知识的想法.一是原来刚开始学习接触编程,一个人跌跌撞撞摸索着往前走,初学的时候很多东西理解的也懵懵懂懂,后来实践的多了,有些东西才慢慢清 楚:二是经过一定的实践之后,反过头来再去学习一些基础东西才能够理解的更透彻:三是有些东西基础但是确很重要,是值得好好搞一搞的. 1.面向对象 面向对象(Object Oriented)是一种新兴的程序设计方法,或者是一种新的程序设计规范(paradigm),

Java反射详解

Java反射详解 分类:java, 基础日期:2012-07-20作者:ticmy 19 反射,是Java中非常重要的一个功能,如果没有反射,可以说很多框架都难以实现. 什么是反射?说白了就是可以通过Java代码获取装载到方法区的类信息的手段. 当装载一个类时,会在方法区产生一个数据结构,该结构中包含着装载的类的相关信息.字节码可以看成是数据流,那么方法区的这种数据结构可以说是字节码数据流的结构化表现.装载的最终产物就是java.lang.Class类的一个对象,它是Java程序与方法区内部数据