首先导入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. Win10怎么打开或关闭自动维护功能

  2. myeclipse中配置schemaLocation路径,实现xml文件自动提示

    在开发中,XML的xsi:schemaLocation路径都是指向网络,但是这个网络地址有时候很不给力导致工程检验XML格式缓慢.所以有必要再myeclipse中配置本地xsd文件路径,以免每次校验都 ...

  3. [svc]msmtp+mutt发附件,发邮件给多个人

    环境:centos6.7 x86-64 内网有web服务器(curl可展示目录) #预安装软件 yum install lrzsz ntpdate sysstat dos2unix wget teln ...

  4. 绝不能错过的10款最新OpenStack网络运维 & 监控工具

    摘要 今天我们要推荐给大家的是关于奥斯汀OpenStack Summit的OpenStack网络方面功能与工具相关的技术演讲. 希望可以帮助国内的开发者.架构师和用户更好地了解OpenStack在SD ...

  5. git commit 、CHANGELOG 和版本发布的标准自动化

    一直以来,因为团队项目迭代节奏很快,每次发布的更新日志和版本更新都是通过人肉来完成的.有时候实在忙的团团转,对于手动的写这些更新信息就显得力不从心了.对于团队新来的小伙伴,有时候遇到些紧急情况,就更显 ...

  6. redis命令_INCR

    INCR key 将 key 中储存的数字值增一. 如果 key 不存在,那么 key 的值会先被初始化为 0 ,然后再执行 INCR 操作. 如果值包含错误的类型,或字符串类型的值不能表示为数字,那 ...

  7. 安装gstreamer开发环境

    ubuntu中安装gstreamer开发环境: * 安装gstreamer基本库,工具,以及插件 sudo apt--dev gstreamer-tools gstreamer0.-tools gst ...

  8. CCNA2.0笔记_安全管理设备

    设备安全 配置Console密码 Switch(config)#line console 0 Switch(config-line)#login Switch(config-line)#passwor ...

  9. 线程同步工具CountDownLatch

    CountDownLatch的一个非常典型的应用场景是:有一个任务想要往下执行,但必须要等到其他的任务执行完毕后才可以继续往下执行.假如我们这个想要继续往下执行的任务调用一个CountDownLatc ...

  10. SSH初体验系列--Hibernate--3--单值与分页查询

    前言 查询可以按结果集分2类:单个结果 和 数组 ; 其中,返回数组,在这个 数据库数据量随随便便就能上几十万的互联网时代大背景下,常常需要做分页处理, 所以这里就说一下单值和分页, 算是对上一篇&q ...