首先导入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. 在Windows8系统下exe格式会计课件下载播放帮助图解

    近期非常多会计从业人员都開始购买课件,開始学习,准备考试:可是网校的课件有些是EXE扩展名格式的,在Windows8系统下播放比較困难.方法比較曲折,这里用图说话,给大家一点參考,希望对大家实用. 下 ...

  2. Certificates

    Certificates Certificates 即 ”证书“,约等于通行证,申请证书是我们进行真机调试与发布的第一步.证书主要分为两类:Development证书用来开发和调试应用程序Produc ...

  3. 点滴积累【C#】---C#实现上传照片到物理路径,并且将地址保存到数据库,

    效果: 思路: 首先,获取图片物理地址,然后进行判断将图片保存到文件夹下,再将图片的信息保存到数据库. 数据库: create table image1 ( ID ,) primary key, Im ...

  4. 在CentOS7系统上执行Scala脚本

    在类Unix系统上,可以在scala文件中开头第一行指定脚本的解释程序.如下例: Script.scala #!/usr/bin/env scala println("Hello" ...

  5. 深度CTR预估模型中的特征自动组合机制演化简史 zz

    众所周知,深度学习在计算机视觉.语音识别.自然语言处理等领域最先取得突破并成为主流方法.但是,深度学习为什么是在这些领域而不是其他领域最先成功呢?我想一个原因就是图像.语音.文本数据在空间和时间上具有 ...

  6. unity Editor下自启动

    [InitializeOnLoad] 加上这个特性,并且在静态构造函数里写上内容.即可在Unity启动的时候自启动这个Editor脚本

  7. excel增加上一列的数值(日期)

    =TEXT(D2-1,"m月d日") 有年的话就是 =TEXT(D2-1,"yyyy年m月d日") D2就是参照日期

  8. Atitit.二维码功能的设计实践 attilax 总结

    Atitit.二维码功能的设计实践 attilax 总结 1.1. 二维码要实现的功能1 1.2. 现有二维码功能设计不足的地方(待改进)1 1.3. 二维码组件1 1.4. Java版  zxing ...

  9. Python 函数进阶(filter/map/json/zip)

    一.函数即变量 def say(name): print(name)ybq = say #可以被赋值给其他变量ybq('Amily') #调用函数 函数名:say 函数体:第1-2行 返回值:retu ...

  10. 数据库设计(七)第三范式(3NF)

    In our last tutorial, we learned about the second normal form and even normalized our Score table in ...