我下载的是 mongo-2.8.0.jar — Version 2.8.0

打开mongo shell -- 新建数据库test --( use test)


打开eclipse新建工程,把junit,mongo-2.8.0.jar导入。


新建测试类如下:


package com.db;

import java.net.UnknownHostException;


import java.util.ArrayList;


import java.util.List;

import org.bson.types.ObjectId;


import org.junit.After;


import org.junit.Test;

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.MongoException;

public class DBUtils {


    private static Mongo mongo;


    private static DB db;


    static {


        try {


            mongo = new Mongo("localhost", 27017);


        } catch (UnknownHostException e) {


            e.printStackTrace();


        } catch (MongoException e) {


            e.printStackTrace();


        }


        db = mongo.getDB("test");


    }

@After


    public void output() {


        // 测试完显示所有


        DBCollection dbc = db.getCollection("user");


        DBCursor cursor = dbc.find();


        while (cursor.hasNext()) {


            // cursor.next就是一行记录(一个文档)


            System.out.println(cursor.next());


        }


    }

@Test


    public void testInsert() throws Exception {


        DBCollection dbc = db.getCollection("user");


        DBObject object = new BasicDBObject();


        object.put("username", "zdw");


        object.put("password", "123");


        // 一个人有一个职位


        // 数据库json格式:{username:"zdw",password:"123",position:{name:"工程师"}}


        BasicDBObject o = new BasicDBObject();


        o.put("name", "经理");


        object.put("position", o);


        dbc.insert(object);

object = new BasicDBObject();


        object.put("username", "zhangjun");


        object.put("password", "456");


        // 一个人有多个职位(一个文档里有多个文档)


        // 数据库json格式:{username:"zhangjun",password:"456",position:[{name:"工程师"},{name:"设计师"}]}


        List<Object> list = new ArrayList<Object>();


        o = new BasicDBObject();


        o.put("name", "工程师");


        list.add(o);


        o = new BasicDBObject();


        o.put("name", "设计师");


        list.add(o);


        object.put("position", list);


        dbc.insert(object);


    }

// 删除指定


    @Test


    public void testRemoveOne() throws Exception {


        DBCollection dbc = db.getCollection("user");


        DBObject o = new BasicDBObject();


        o.put("username", "zhangjun");


        dbc.remove(o);


    }

@Test


    public void testModify() throws Exception {


        DBCollection dbc = db.getCollection("user");


        // 根据id修改密码,需要加$set,否则所有记录的password都会被修改,其它字段删除。


        int result = dbc.update(


                        new BasicDBObject("_id", new ObjectId(


                                "4ff8eaa65dbc67340278a07c")),


                        new BasicDBObject("$set", new BasicDBObject("password",


                                "4444"))).getN();


        System.out.println(result);


    }

@Testhttp://www.shengshiyouxi.com


    public void testRemove() throws Exception {


        DBCollection dbc = db.getCollection("user");


        // 删除全部


        dbc.drop();


    }

// 查询指定


    @Test


    public void testFindOne() throws Exception {


        DBCollection dbc = db.getCollection("user");


        DBObject o = new BasicDBObject();


        o.put("username", "zdw");


        DBObject obj = dbc.findOne(o);


        System.out.println(obj);


    }

}

这种key-value存储方式,操作很方便。


源码下载

mongodb之java CRUD 简单操作的更多相关文章

  1. github上创建java项目简单操作

    github上创建java项目简单操作 参考L: github上创建java项目简单操作 - CSDN博客http://blog.csdn.net/qq_29392425/article/detail ...

  2. MongoDB快速入门学习笔记2 MongoDB的概念及简单操作

    1.以下列举普通的关系型数据库和MongoDB数据库简单概念上的区别: 关系型数据库 MongoDB数据库 说明 database database 数据库 table collection 数据库表 ...

  3. Mongodb系列- java客户端简单使用(CRUD)

    Mongodb提供了很多的客户端: shell,python, java, node.js...等等. 以 java 为例实现简单的增删改查 pom文件: <dependencies> & ...

  4. Java 数据库简单操作类

    数据库操作类,将所有连接数据库的配置信息以及基本的CRUD操作封装在一个类里,方便项目里使用,将连接数据库的基本信息放在配置文件 "dbinfo.properties" 中,通过类 ...

  5. 【MongoDB】5.MongoDB与java的简单结合

    1.首先 你的清楚你的MongoDB的版本是多少  就下载对应的架包 下载地址如下: http://mongodb.github.io/mongo-java-driver/ 2.新建一个项目  把架包 ...

  6. python下的orm基本操作(1)--Mysql下的CRUD简单操作(含源码DEMO)

    最近逐渐打算将工作的环境转移到ubuntu下,突然发现对于我来说,这ubuntu对于我这种上上网,收收邮件,写写博客,写写程序的时实在是太合适了,除了刚接触的时候会不怎么完全适应命令行及各种权限管理, ...

  7. 跟着大神学Mongo,Mongodb主从复制本机简单操作总结

    原文链接:http://www.cnblogs.com/huangxincheng/archive/2012/03/04/2379755.html 本机安装MongoDB不在介绍,本文Mongo小菜鸟 ...

  8. zookeeper Java API 简单操作示例

    本文主要介绍如何在java IDE中如何应用使用客户端与zookeeper服务器通信. 首先搭建maven环境,并在pom文件中加入zookeeper引用包: <!-- https://mvnr ...

  9. mongodb的安装与简单操作

    MongoDB中文社区:http://www.mongoing.com     数据库的使用场景 SQL(关系型数据库):MySQL.SQLServer  --->磁盘操作 1.高度事务性的场景 ...

随机推荐

  1. Android 3d云标签

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbWluZ3l1ZV8xMTI4/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...

  2. 经常使用MD5算法代码

    经常使用的MD5算法代码日期: 2014年8月4日作者: 铁锚 MD5,全称为 Message Digest Algorithm 5(消息摘要算法第五版).详情请參考 维基百科:MD5  MD5加密后 ...

  3. css怎样使顶端悬浮导航栏不遮住下面一层页面内容

    在两个层之间加这个<span class="blank" style="height:20px;"></span>,其中高度可以自己设置 ...

  4. C/C++ Resources

    C/C++ Resources 一.C/C++相关资源 语言标准及文档● ISO C99http://www.open-std.org/JTC1/SC22/WG14/www/docs/n1124.pd ...

  5. 8086 CPU 寻址方式

    8086 CPU 寻址方式灵活.有以下几种 idata 表示常量 1.   [ idata ] 用一个常量来表示地址,可用于直接定位内存单元,但是在 MASM中要显实在的说明 ds 段寄存器, 比如 ...

  6. Jetty:配置安全

    用${jetty.home}和${jetty.base}配置安全 Jetty 9.1中:  1)${jetty.home}是jetty公布(二进制)的文件夹路径:  2)${jetty.base}是用 ...

  7. 类型自动转换引起的误解——QString可以赋值数字1,也能直接与0比较,真是昏倒!

    看以下代码,能编译通过: void MainWindow::on_pushButton_clicked() { QString str = "test"; ) { QMessage ...

  8. ThinkPHP中实例化对象M()和D()的区别,select和find的区别

    原文:ThinkPHP中实例化对象M()和D()的区别,select和find的区别 1.ThinkPHP中实例化对象M()和D()的区别 在实例化的过程中,经常使用D方法和M方法,这两个方法的区别在 ...

  9. 飘逸的python - yield简明教程

    发现还有非常多人对yield不理解,云里雾里,于是试着用文字表述. 仅仅要函数含有yield语句,它就返回一个生成器.所以我们与其把其看成函数定义,不如看作是生成器定义.函数用return返回,而生成 ...

  10. ORACLE—005:创建JOB(二)

    假设须要创建带參数的job,怎样创建呢. 我们直接将參数声明.并赋值.然后传给job调用的存储过程就可以. 比如.存储过程名为Pro_Test_JOB,參数共同拥有一个.是VARCHAR2类型. 创建 ...