mongodb 去重查询 Java,mongodb篇二:mongodb克隆远程数据库,去重查询的命令及对应java语句...

本文介绍了如何使用Java连接MongoDB数据库并进行基本操作,包括查询、去重、克隆数据库等。通过示例代码展示了如何执行查询语句,如按条件筛选数据、计数以及去重查询。同时提供了连接MongoDB的Java代码示例和相关依赖的jar包信息。
摘要由CSDN通过智能技术生成

另外附上mongodb eclipse插件地址: http://www.jumperz.net/update/ import java.net.UnknownHostException;import com.mongodb.DB;import com.mongodb.DBCol

1.首先操作mongodb最基本命令::

show databases;             ---------------------显示全部数据库

use 数据库名;        --------------------切换到指定数据库

show collections;  --------------------显示该数据库下的全部表

之后就可以执行相应增删改查语句了!

2.

查询:  logger  是我自己的数据库表名

db.logger.find()  查询全部,数据过多的话继续执行 it 就可以继续显示下一页数据,重复再重复

db.logger.count()     查询数量

db.logger.find({"device":"mobile"})     查询device是mobile的数据

指定条件下查询:

db.logger.find(

{"device":"mobile","datetime":{"$gt":1384185600000,"$lt":1384271999000}}

);

查询指定device是mobile,时间在1384185600000到1384271999000之间的logger,这里的数字是时间类型对应的毫秒数,1384185600000对应“2013-11-12 00:00:00”,1384271999000对应2013-11-12 23:59:59,也就是11月12号这一天

db.logger.find(

{"device":"mobile","datetime":{"$gt":1384185600000,"$lt":1384271999000}}

).count();

后面加上count,查询上面集合的数量

去重查询:

db.runCommand(

{"distinct":"数据库表名","key":"要去重的属性名","query":{“查询语句”}}

);

返回的是去重的集合,在query后面的查询语句中放入自己想加入的条件即可,就像上面指定条件下查询:的find()里面指定的查询语句{"device":"mobile","datetime":{"$gt":1384185600000,"$lt":1384271999000}}

db.runCommand(

{"distinct":"数据库表名","key":"要去重的属性名","query":{“查询语句”}}

).values.length; 后面加上 .values.length,返回去重查询后的数量

3.克隆远程数据库:

db.copyDatabase("目标数据库","我自己的数据库名","ip地址:端口号")

就像这样

db.copyDatabase("web_logger","MyDB","110.110.10.110:27012")

执行后就可以把ip是110.110.10.110的远程数据库web_logger拉到本地mongodb数据库内上一篇我们讲了MongoDB 的命令入门初探,本篇blog将基于上一篇blog所建立的数据库和表完成一个简单的Java MongoDB CRUD Example,利用Java连接MongoDB数据库,并

对应的java语句:

连接mongodb数据库:

public DBCollection getCollection(String tableName) {

DBCollection collection = null;

try {

Mongo mongo = new Mongo("XXXX.XXX.XX.XXX",27017);

DB db = mongo.getDB("web_logger");

collection = db.getCollection(tableName);

System.out.println("已连接"+tableName+"表");

} catch (UnknownHostException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

return collection;

}

传入表名,返回该表的连接!

查询指定条件的数据:

DBObject query = new BasicDBObject();

query.put("device","web");

query.put("city","杭州");

query.put("datetime", new BasicDBObject("$gte",1384185600000).append("$lte",1384271999000));

DBCollection collection = 连接自己定义的数据库表.

之后几种情况的查询

1.查询数量

long num = collection.count(query);

2.查询去重数量

long num = collection.distinct("ip",query).size();

3.查询集合

List list = new ArrayList();

DBCurson curson = collection.find(query);

Gson gson = new Gson();

while(curson.hasNext()){

DBObject element = curson.next();

Logger logger = gson.fromJson(element.toString(), Logger.class);

list.add(logger);

}

return list;

4.查询去重集合:

List list = collection.distinct("ip",query);

OVER!简单地用到了一些,暂时记着方便以后回忆

对了,贴上用到的jar包

org.mongodb

mongo-java-driver

2.11.3

com.google.code.gson

gson

2.2.4

org.springframework.data

spring-data-mongodb

1.0.0.M5

1.使用eclipse创建一个maven项目开操作mongodb数据库。pom.xml文件如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值