首先导入mongoDB的jar包 http://pan.baidu.com/s/1bnGMJRD

//DataBase.java

package com.mongodb.test;

import java.net.UnknownHostException;

import com.mongodb.DB; 
import com.mongodb.DBCollection; 
import com.mongodb.DBCursor; 
import com.mongodb.DBObject; 
import com.mongodb.Mongo; 
import com.mongodb.MongoException; 
import com.mongodb.util.JSON;

public class DataBase { 
 public static void main(String[] args) 
  throws UnknownHostException, MongoException { 
  //1.建立一个Mongo的数据库连接对象 
  Mongo mg = new Mongo("127.0.0.1:27017"); 
        //查询所有的Database 
        for (String name : mg.getDatabaseNames()) { 
            System.out.println("dbName: " + name); 
        } 
        //2.创建相关数据库的连接 
        DB db = mg.getDB("foobar"); 
        //查询数据库所有的集合 
        for (String name : db.getCollectionNames()) { 
            System.out.println("collectionName: " + name); 
        } 
        
        DBCollection users = db.getCollection("persons"); 
        //查询所有的数据 
        DBCursor cur = users.find(); 
        while (cur.hasNext()) { 
         DBObject object = cur.next(); 
         System.out.println(object.get("name")); 
        } 
        System.out.println(cur.count()); 
        System.out.println(cur.getCursorId()); 
        System.out.println(JSON.serialize(cur)); 
    } 

//MongoDb.java

package com.mongodb.test;

import java.net.UnknownHostException; 
import java.util.List;

import org.bson.types.ObjectId;

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 MongoDb { 
 //1.建立一个Mongo的数据库连接对象 
 static Mongo connection = null; 
 //2.创建相关数据库的连接 
 static DB db = null; 
 public MongoDb(String dbName) throws UnknownHostException, MongoException{ 
  connection = new Mongo("127.0.0.1:27017"); 
  db = connection.getDB(dbName); 
 } 
 public static void main(String[] args) throws UnknownHostException, MongoException { 
  //实例化 
  MongoDb mongoDb = new MongoDb("foobar"); 
     /** 
      * 1.创建一个名字叫javadb的数据库 
      */ 
//  mongoDb.createCollection("javadb"); 
  /** 
   * 2.为集合javadb添加一条数据 
   */ 
//  DBObject dbs = new BasicDBObject(); 
//  dbs.put("name", "uspcat.com"); 
//  dbs.put("age", 2); 
//  List<String>  books = new ArrayList<String>(); 
//  books.add("EXTJS"); 
//  books.add("MONGODB"); 
//  dbs.put("books", books); 
//  mongoDb.insert(dbs, "javadb"); 
  /** 
   * 3.批量插入数据 
   */ 
//  List<DBObject> dbObjects = new ArrayList<DBObject>(); 
//  DBObject jim = new BasicDBObject("name","jim"); 
//  DBObject lisi = new BasicDBObject("name","lisi"); 
//  dbObjects.add(jim); 
//  dbObjects.add(lisi); 
//  mongoDb.insertBatch(dbObjects, "javadb"); 
  /** 
   * 4.根据ID删除数据 
   */ 
//  mongoDb.deleteById("502870dab9c368bf5b151a04", "javadb"); 
  /** 
   * 5.根据条件删除数据 
   */ 
//  DBObject lisi = new BasicDBObject(); 
//  lisi.put("name", "lisi"); 
//  int count = mongoDb.deleteByDbs(lisi, "javadb"); 
//  System.out.println("删除数据的条数是: "+count); 
  /** 
   * 6.更新操作,为集合增加email属性 
   */ 
//  DBObject update = new BasicDBObject(); 
//  update.put("$set", 
//    new BasicDBObject("eamil","test @126.com")); 
//  mongoDb.update(new BasicDBObject(), 
//    update,false,true,"javadb"); 
  /** 
   * 7.查询出persons集合中的name和age 
   */ 
//  DBObject keys = new BasicDBObject(); 
//  keys.put("_id", false); 
//  keys.put("name", true); 
//  keys.put("age", true); 
//  DBCursor cursor = mongoDb.find(null, keys, "persons"); 
//     while (cursor.hasNext()) { 
//      DBObject object = cursor.next(); 
//      System.out.println(object.get("name")); 
//     } 
     /** 
      * 7.查询出年龄大于26岁并且英语成绩小于80分 
      */ 
//  DBObject ref = new BasicDBObject(); 
//  ref.put("age", new BasicDBObject("$gte",26)); 
//  ref.put("e", new BasicDBObject("$lte",80)); 
//  DBCursor cursor = mongoDb.find(ref, null, "persons"); 
//     while (cursor.hasNext()) { 
//      DBObject object = cursor.next(); 
//      System.out.print(object.get("name")+"-->"); 
//      System.out.print(object.get("age")+"-->"); 
//      System.out.println(object.get("e")); 
//     } 
  /** 
   * 8.分页例子 
   */ 
  DBCursor cursor = mongoDb.find(null, null, 0, 3, "persons"); 
     while (cursor.hasNext()) { 
      DBObject object = cursor.next(); 
      System.out.print(object.get("name")+"-->"); 
      System.out.print(object.get("age")+"-->"); 
      System.out.println(object.get("e")); 
     }   
  //关闭连接对象 
  connection.close(); 
 } 
 /** 
  * 穿件一个数据库集合 
  * @param collName 集合名称 
  * @param db  数据库实例 
  */ 
 public void createCollection(String collName){ 
  DBObject dbs = new BasicDBObject(); 
  db.createCollection("javadb", dbs); 
 } 
 /** 
  * 为相应的集合添加数据 
  * @param dbs 
  * @param collName 
  */ 
 public void insert(DBObject dbs,String collName){ 
  //1.得到集合 
  DBCollection coll = db.getCollection(collName); 
  //2.插入操作 
  coll.insert(dbs); 
 } 
 /** 
  * 为集合批量插入数据 
  * @param dbses 
  * @param collName 
  */ 
 public void insertBatch(List<DBObject> dbses,String collName){ 
  //1.得到集合 
  DBCollection coll = db.getCollection(collName); 
  //2.插入操作 
  coll.insert(dbses); 
 } 
 /** 
  * 根据id删除数据 
  * @param id 
  * @param collName 
  * @return 返回影响的数据条数 
  */ 
 public int deleteById(String id,String collName){ 
  //1.得到集合 
  DBCollection coll = db.getCollection(collName); 
  DBObject dbs = new BasicDBObject("_id", new ObjectId(id)); 
  int count = coll.remove(dbs).getN(); 
  return count; 
 } 
 /** 
  * 根据条件删除数据 
  * @param id 
  * @param collName 
  * @return 返回影响的数据条数 
  */  
 public int deleteByDbs(DBObject dbs,String collName){ 
  //1.得到集合 
  DBCollection coll = db.getCollection(collName); 
  int count = coll.remove(dbs).getN(); 
  return count; 
 } 
 /** 
  * 更新数据 
  * @param find 查询器 
  * @param update 更新器 
  * @param upsert 更新或插入 
  * @param multi 是否批量更新 
  * @param collName 集合名称 
  * @return 返回影响的数据条数 
  */ 
 public int update(DBObject find, 
      DBObject update, 
      boolean upsert, 
      boolean multi, 
      String collName){ 
  //1.得到集合 
  DBCollection coll = db.getCollection(collName); 
  int count = coll.update(find, update, upsert, multi).getN(); 
  return count; 
 } 
 /** 
  * 查询器(分页) 
  * @param ref 
  * @param keys 
  * @param start 
  * @param limit 
  * @return 
  */ 
 public DBCursor find(DBObject ref, 
   DBObject keys, 
   int start, 
   int limit, 
   String collName){ 
  DBCursor cur = find(ref, keys, collName); 
  return cur.limit(limit).skip(start); 
 } 
 /** 
  * 查询器(不分页) 
  * @param ref 
  * @param keys 
  * @param start 
  * @param limit 
  * @param collName 
  * @return 
  */ 
 public DBCursor find(DBObject ref, 
   DBObject keys, 
   String collName){ 
  //1.得到集合 
  DBCollection coll = db.getCollection(collName); 
  DBCursor cur = coll.find(ref, keys); 
  return cur; 
 }  
}

java操作mongoDB数据库的简单实例的更多相关文章

  1. JAVA操作MongoDB数据库

    1. 首先,下载MongoDB对Java支持的驱动包 驱动包下载地址:https://github.com/mongodb/mongo-java-driver/downloads 2.Java操作Mo ...

  2. java操作mongodb数据库实现新建数据库,新建集合,新建文档

    *首先明确一点,要通过java代码创建mongodb数据库实例,需要同时创建集合和文档. 代码实现: /* 建立与mongodb数据库的连接,可指定参数,如:MongoClient client = ...

  3. java对mongodb数据库的简单操作

    准备工作: 下载好mongodriver.jar包(https://oss.sonatype.org/content/repositories/releases/org/mongodb/mongodb ...

  4. PHP操作MongoDB数据库的示例

    http://www.jquerycn.cn/a_8137 本节内容:PHP操作MongoDB数据库的简单示例. Mongodb的常用操作参看手册,php官方的http://us2.php.net/m ...

  5. java连接mongodb数据库

    最近毕设需要用到这个数据库.然而又不会,没办法,只能上网学习学习. 记录一下java连接mongodb数据库的简单方法.这里只是记录一下学习.熟悉一下CURD方法. 但是毕业用到的是SpringBoo ...

  6. python操作三大主流数据库(7)python操作mongodb数据库①mongodb的安装和简单使用

    python操作mongodb数据库①mongodb的安装和简单使用 参考文档:中文版:http://www.mongoing.com/docs/crud.html英文版:https://docs.m ...

  7. 不使用spring的情况下原生java代码两种方式操作mongodb数据库

    由于更改了mongodb3.0数据库的密码,导致这几天storm组对数据进行处理的时候,一直在报mongodb数据库连接不上的异常.   主要原因实际上是和mongodb本身无关的,因为他们改的是配置 ...

  8. 不使用spring的情况下用java原生代码操作mongodb数据库的两种方式

    由于更改了mongodb3.0数据库的密码,导致这几天storm组对数据进行处理的时候,一直在报mongodb数据库连接不上的异常.   主要原因实际上是和mongodb本身无关的,因为他们改的是配置 ...

  9. C# Asp.net中简单操作MongoDB数据库(二)

    C# Asp.net中简单操作MongoDB数据库(一)    , mongodb数据库连接可以回顾上面的篇幅. 1.model类: public class BaseEntity { /// < ...

随机推荐

  1. Java并发编程(五):Java线程安全性中的对象发布和逸出

    发布(Publish)和逸出(Escape)这两个概念倒是第一次听说,不过它在实际当中却十分常见,这和Java并发编程的线程安全性就很大的关系. 什么是发布?简单来说就是提供一个对象的引用给作用域之外 ...

  2. 常见typedef 用法

    1.常规变量类型定义例如:typedef unsigned char uchar描述:uchar等价于unsigned char类型定义      uchar c声明等于unsigned char c ...

  3. [docker]bind9.11-with-mysql5.6 docker容器化实战

    参考: https://www.centos.bz/2012/09/bind-with-mysql-support/ http://blog.51niux.com/?id=125 http://470 ...

  4. Effective JavaScript Item 37 认识this的隐式指向

    本系列作为Effective JavaScript的读书笔记. CSV数据通常都会被某种分隔符进行分隔.所以在实现CSV Reader时,须要支持不同的分隔符.那么,非常自然的一种实现就是将分隔符作为 ...

  5. gpg: symbol lookup error

    今天使用sudo apt-get 安装包的时候,出现gpg错误,如下: gpg: symbol lookup error: /usr/local/lib/libreadline.so.6: undef ...

  6. ld -l选项注意事项

    在程序中用到某个静态库,使用命令: gcc bin -llibrary.a object.o 结果发现找不到library.a中的某些函数符号 undefine reference to ... 通过 ...

  7. CCNA2.0笔记_路由相关

    路由器的工作内容 -路由器知道目标地址 -发现到达目标地址的可能的路由 -选择最佳路径(路由表) -维护路由信息 路由的来源 直连路由:直接连到路由器上的网络 -初始化情况下,路由器所知的网络,只有其 ...

  8. powerDesigner建表时选择不同数据库类型

    l  使用powerDesigner创建表模型的时候可选择数据库类型 如图设置为mysql:

  9. CentOS/Linux 网卡设置 IP地址配置永久生效

    CentOS/Linux下设置IP地址 1.临时生效设置 1.1修改IP地址 #ifconfig eth0 192.168.100.100 1.2修改网关地址 #route add default g ...

  10. UVA 11732 &quot;strcmp()&quot; Anyone? (Trie)

    题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...