java操作mongodb示例分享

代码如下:

package mymaven;

import java.net.UnknownHostException; 
import java.util.Set;

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 Test { 
    public static void main(String[] args) throws UnknownHostException, MongoException { 
        Mongo mongo = new Mongo("172.27.9.104", 27017);     // 连接数据库 
        DB db = mongo.getDB("mytestdb");                    // 数据库 
        Set<String> cols = db.getCollectionNames();           // 获取数据库中所有的集合(类似于获取关系数据库中的表)

// 打印出数据库中的集合,这里应当为null 
        for (String s : cols) { 
            System.out.println(s); 
        }

DBCollection collection = db.getCollection("mytestcoll");       // 创建一个集合 
        collection.drop();                                              // 删除集合,插入数据时自动重建 
        BasicDBObject obj = new BasicDBObject();                        // 初始化一个基本DB对象,插入数据库的就是DB对象

obj.put("from", "blog.ithomer.net");        // 放入几个键值对 
        obj.put("to", "forum.ithomer.net"); 
        obj.put("subject", "ithomer.net"); 
        collection.insert(obj);                     // 插入对象

DBObject dbobj = collection.findOne();      // 查看一条记录,findOne()=find().limit(1); 
        System.out.println(dbobj);                  // 打印出刚才插入的数据

// 插入10条{ranking:i}的数据 
        for (int i = 0; i < 10; i++) { 
            collection.insert(new BasicDBObject().append("ranking", i)); 
        } 
        System.out.println("count: " + collection.getCount());      // 打印集合中的数据总数

DBCursor cursor = collection.find();        // 然后我们使用这个游标来遍历集合 
        while (cursor.hasNext()) { 
            System.out.println(cursor.next()); 
        } 
        // 简单的条件查询,查询ranking为1的记录 
        BasicDBObject query = new BasicDBObject(); 
        query.put("ranking", 1); 
        cursor = collection.find(query); 
        System.out.println("collection find({\"ranking\":1}):"); 
        while (cursor.hasNext()) { 
            System.out.println(cursor.next()); 
        }

// 复杂的条件查询,查询ranking大于等于5小于9的记录 
        query = new BasicDBObject(); 
        query.put("ranking", new BasicDBObject("$gte", 5).append("$lt", 9)); 
        cursor = collection.find(query); 
        System.out.println("collection find({\"ranking\":[5-9)}):"); 
        while (cursor.hasNext()) { 
            System.out.println(cursor.next()); 
        }

//      mongo.dropDatabase("mytestdb");         // 最后删除我们的测试数据库 
    } 
}

运行结果:

代码如下:

mytestcoll
system.indexes
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd10107"} , "from" : "blog.ithomer.net" , "to" : "forum.ithomer.net" , "subject" : "ithomer.net"}
count: 11
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd10107"} , "from" : "blog.ithomer.net" , "to" : "forum.ithomer.net" , "subject" : "ithomer.net"}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd10108"} , "ranking" : 0}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd10109"} , "ranking" : 1}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd1010a"} , "ranking" : 2}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd1010b"} , "ranking" : 3}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd1010c"} , "ranking" : 4}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd1010d"} , "ranking" : 5}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd1010e"} , "ranking" : 6}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd1010f"} , "ranking" : 7}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd10110"} , "ranking" : 8}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd10111"} , "ranking" : 9}
collection find({"ranking":1}):
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd10109"} , "ranking" : 1}
collection find({"ranking":[5-9)}):
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd1010d"} , "ranking" : 5}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd1010e"} , "ranking" : 6}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd1010f"} , "ranking" : 7}
{ "_id" : { "$oid" : "52c62ed8e4b0f4de3dd10110"} , "ranking" : 8}

mongodb数组示例:

代码如下:

@SuppressWarnings("unchecked")
 public static void loadMediaTags(List<MediaEntity> mediaEntityList) {
  mediaEntityList.clear();

try {
   Mongo mongo = new Mongo(CosineCluster.gMongo_HOST, CosineCluster.gMongo_PORT);
   DB db = mongo.getDB(CosineCluster.gMongo_DB);
   DBCollection collection = db.getCollection(CosineCluster.gMongo_Coll_Media);

DBCursor cursor = collection.find();
   int index = 0;
   long startTime = System.currentTimeMillis();
   while(cursor.hasNext()){
    BasicDBObject obj = (BasicDBObject) cursor.next();

long id = obj.getLong("_id");
    ArrayList<String> tagList = (ArrayList<String>) obj.get("tag");     // tag
    ArrayList<String> keywordList = (ArrayList<String>)obj.get("keyword");   // keyword
    ArrayList<Integer> copyrightList = (ArrayList<Integer>)obj.get("copyright"); // copyright

MediaEntity mediaEntity = new MediaEntity();

mediaEntity.setId(id);

// tag
    for(int j=0; j<tagList.size(); j++) {
     mediaEntity.addTag(tagList.get(j));
     int tagId = getTagInt(tagList.get(j));
     mediaEntity.addTag(tagId);
    }

// actors
    ArrayList<DBObject> actorsObjList = (ArrayList<DBObject>)obj.get("actors");  // actors
    for(int j=0; j<actorsObjList.size(); j++) {
      mediaEntity.addActor((String) actorsObjList.get(j).get("name")); 
      int actorId = getActorInt((String)actorsObjList.get(j).get("name"));
      mediaEntity.addActor(actorId);
    }

// director
    ArrayList<DBObject> directorObjList = (ArrayList<DBObject>)obj.get("director"); // director
    for(int j=0; j<directorObjList.size(); j++) {
      mediaEntity.addDirector((String) directorObjList.get(j).get("name")); 
      int directorId = getDirectorInt((String) directorObjList.get(j).get("name"));
      mediaEntity.addDirector(directorId);
    }

// keyword
    for(int j=0; j<keywordList.size(); j++) {
     mediaEntity.addKeyword(keywordList.get(j));
     int keywordId = getKeywordInt(keywordList.get(j));
     mediaEntity.addKeyword(keywordId);
    }

// copyright
    for(int j=0; j<copyrightList.size(); j++) {
     mediaEntity.addCopyright(copyrightList.get(j));
    }

mediaEntityList.add(mediaEntity);

index++;
    if(index > 100) {
     break;
    }
    System.out.println(index + " --- mediaEntity : " + mediaEntity.toString());
   }
   long costTime = System.currentTimeMillis() - startTime;
   System.out.println("load data costTime = " + index + "; costTime = " + costTime/1000f);

} catch (Exception e) {
   e.printStackTrace();
  }
 }

public static int getTagInt(String tag) {
  int tagIntId = -1;

try {
   MongoClient mongo = new MongoClient(CosineCluster.gMongo_HOST, CosineCluster.gMongo_PORT);
   DB db = mongo.getDB(CosineCluster.gMongo_DB);
   DBCollection tagmapCollection = db.getCollection("recommend_tag_map");

DBCursor cursor = tagmapCollection.find(new BasicDBObject("name", tag)); 
   if(cursor == null || cursor.toArray().size() <= 0) {  // 处理小于2或n的映射关键字,下同
    return tagIntId;
   }
   DBObject obj = cursor.toArray().get(0);

String name = tag;
   tagIntId = (Integer) obj.get("id");
   int num = (Integer) obj.get("num");

mongo.close();
  } catch (UnknownHostException e) {
   e.printStackTrace();
  }

return tagIntId;
 }

public static int getActorInt(String actor) {
  int actorIntId = -1;
  try {
   MongoClient mongo = new MongoClient(CosineCluster.gMongo_HOST, CosineCluster.gMongo_PORT);
   DB db = mongo.getDB(CosineCluster.gMongo_DB);
   DBCollection tagmapCollection = db.getCollection("recommend_actor_map");

DBCursor cursor = tagmapCollection.find(new BasicDBObject("name", actor));
   if(cursor == null || cursor.toArray().size() <= 0) {
    return actorIntId;
   }
   DBObject obj = cursor.toArray().get(0);

String name = actor;
   actorIntId = (Integer) obj.get("id");
   int num = (Integer) obj.get("num");

mongo.close();
  } catch (UnknownHostException e) {
   e.printStackTrace();
  }

return actorIntId;
 }

(0)

相关推荐

  • java操作mongodb基础(查询 排序 输出list)

    复制代码 代码如下: package com.infomorrow.webroot; import java.util.List; import com.mongodb.BasicDBObject;import com.mongodb.DB;import com.mongodb.DBCollection;import com.mongodb.DBCursor;import com.mongodb.DBObject;import com.mongodb.MongoClient; public cl

  • java查询mongodb中的objectid示例

    找了很久查询objectid的方法都是错的,用mongovue能查询出来,但就是用java不知道怎么查询 1.mongovue里的查询方式: 复制代码 代码如下: {"_id" : ObjectId("5326bfc0e6f780b21635248f")} 2.纯mongodb里的查询方式: 复制代码 代码如下: db.collect.find({ "_id" : ObjectId("5326bfc0e6f780b21635248f&q

  • Java操作MongoDB数据库示例分享

    MongoDB是一个文档型数据库,是NOSQL家族中最重要的成员之一,以下代码封装了MongoDB的基本操作. MongoDBConfig.java package com.posoftframework.mongodb; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.util.Enumeration; import java.util.HashMap; i

  • java操作mongodb实现CURD功能实例

    先下载相应的驱动:官网上下载:http://central.maven.org/maven2/org/mongodb/mongo-java-driver/本文使用mongo-2.10.1.jar版本: 下面有详细代码的,每个方法可以单独执行.其中为了方便运行,每个方法中都重新链接数据库,而没有再提出来,因为在此的目的是为了认识mongodb而已. 复制代码 代码如下: package com.mongo.dao;import com.mongodb.BasicDBObject;import co

  • MongoDB快速入门笔记(八)之MongoDB的java驱动操作代码讲解

    MongoDB的Java驱动是线程安全的,对于一般的应用,只要一个Mongo实例即可,Mongo有个内置的连接池(池大小默认为10个). 下面代码给大家介绍MongoDB的java驱动操作,具体代码如下所示: import java.util.ArrayList; import java.util.List; import java.util.regex.Pattern; import org.bson.Document; import com.mongodb.MongoClient; impo

  • MongoDB系列教程(六):java操作mongodb实例

    java操作mysql数据库的代码我们已经了如指掌了,增删改查,java对mongodb数据库也是类似的操作,先是数据库连接,再是进行操作. 首先我们进入进入admin数据库,然后建立自己的数据库testMongoDb,进入admin数据库后,就可以直接进入testMongoDb,因为用户可以进入系统的数据库,就是超级管理员,use testMongoDb后,为该数据库设置用户名和密码,db.addUser('root','root'),这样我们在程序中连该数据库,并实现增删改查,代码如下所示.

  • Java连接MongoDB进行增删改查的操作

    Java连接MongoDB进行增删改查的操作 1.创建数据库的连接,进行增删改查 (分别为接口和实现类) package com.dao; import java.util.List; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mo

  • MongoDB支持的java数据类型和测试例子

    mongodb的java数据类型有: Object Ids 自动IDRegular Expressions 正则表达式搜索记录Dates/Times 时间Database References 数据基础结构Binary Data 二进制流Timestamp Data 时间标记戳Code Data 代码数据Embedded Documents 嵌入式文档Arrays 数组类型 详细参考原来英文 http://docs.mongodb.org/ecosystem/drivers/java-types

  • java实现mongodb的数据库连接池

    MongoDB是介于关系数据库和非关系数据库之间的一种产品,文件的存储格式为BSON(一种JSON的扩展),这里就主要介绍Java通过使用mongo-2.7.3.jar包实现mongodb连接池,具体的java代码实现如下: 数据库连接池配置参数: /** *@Description: mongo连接池配置文件 */ package cn.lulei.mongo.pool; public class MongoConfig { private static String userName;//用

  • java操作mongodb示例分享

    复制代码 代码如下: package mymaven; import java.net.UnknownHostException;  import java.util.Set; import com.mongodb.BasicDBObject;  import com.mongodb.DB;  import com.mongodb.DBCollection;  import com.mongodb.DBCursor;  import com.mongodb.DBObject;  import c

  • 【MongoDB for Java】Java操作MongoDB数据库

    本篇文章主要介绍Java操作MongoDB. 开发环境: System:Windows IDE:eclipse.MyEclipse 8 Database:mongoDB 开发依赖库: JavaEE5.mongo-2.5.3.jar.junit-4.8.2.jar 一.准备工作 1. 首先,下载mongoDB对Java支持的驱动包 驱动包下载地址:http://www.jb51.net/softs/41751.html mongoDB对Java的相关支持.技术:http://www.mongodb

  • Java操作Mongodb数据库实现数据的增删查改功能示例

    本文实例讲述了Java操作Mongodb数据库实现数据的增删查改功能.分享给大家供大家参考,具体如下: 首先,我们在windows下安装mongodb数据库,安装教程可查看前面一篇文章:http://www.jb51.net/article/85605.htm 代码如下: package io.mogo; import java.util.Map; import org.apache.commons.lang3.StringUtils; import com.mongodb.BasicDBObj

  • Java操作MongoDB数据库的示例代码

    mongodb-driver是mongo官方推出的java连接mongoDB的驱动包,相当于JDBC驱动. 环境准备 step1:创建工程 , 引入依赖 <dependencies> <dependency> <groupId>org.mongodb</groupId> <artifactId>mongodb‐driver</artifactId> <version>3.6.3</version> </d

  • Java操作MongoDB模糊查询和分页查询

    本文实例为大家分享了Java操作MongoDB模糊查询和分页查询,供大家参考,具体内容如下 模糊查询条件: 1.完全匹配 Pattern pattern = Pattern.compile("^name$", Pattern.CASE_INSENSITIVE); 2.右匹配 Pattern pattern = Pattern.compile("^.*name$", Pattern.CASE_INSENSITIVE); 3.左匹配 Pattern pattern =

  • java操作mongodb时,对象bean和DBObject相互转换的方法(推荐)

    如下所示: package com.iqbon.spider.util; import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.util.Date; import org.apache.commons.beanutils.BeanUtils; import com.mongodb.BasicDBObject; import com.mongodb.DBObje

  • java操作mongodb之多表联查的实现($lookup)

    最近在开发的过程中,一个列表的查询,涉及到了多表的关联查询,由于持久层使用的是mongodb,对这个非关系型数据使用的不是很多,所以在实现此功能的过程中出现了不少问题,现在此做记录,一为加深自己的理解,以后遇到此类问题可以快速的解决,二为遇到同样问题的小伙伴提供一点小小的帮助. 全文分为两部分: 使用robo3t编写多表关系的查询语句 将编写的查询语句整合到java项目 多表联查的查询语句: 此处使用的为mongodb的robo3t可视化工具,先说下需求:从A(假如说是日志表)表中查询出符合条件

  • GO语言操作Elasticsearch示例分享

    目录 Elasticsearch简介 连接Elasticsearch 创建索引 创建model结构体 初始化model 创建索引 搜索数据 创建返回结构体 搜索数据 解析数据 修改数据 单条修改 批量修改 删除数据 单条删除 批量删除 Elasticsearch简介 Elasticsearch 是一个开源的搜索引擎,建立在一个全文搜索引擎库 Apache Lucene™ 基础之上. Lucene 可以说是当下最先进.高性能.全功能的搜索引擎库–无论是开源还是私有. 连接Elasticsearch

  • java操作mongoDB查询的实例详解

    java操作mongo查询的实例详解 前言: MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的.他支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型.Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且

随机推荐