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

另外附上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文件如下:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/571458.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML5 规范

在学习编程的时候,每次看到那些整齐规范的代码,心里顿时对这个程序员表示点点好感,有时,比如看到自己和朋友写的代码时,那阅读起来就是苦不堪言,所以,一些基本的开发规范是必须的,是…

python提交事务_事务提交和回滚

操作方法begin; -开始事物commit; - 提交事物 Python 默认是取消自动提交的rollback; - 回撤操作, 只要操作没有执行 commit 就可以进行回滚操作, 撤回create table tb_account(accid char(4) not null,uname varchar(20) not null,balance float default 0)insert into tb_ac…

求数组的最大值php,求PHP数组最大值,最小值的代码

求PHP数组最大值,最小值的代码,需要的朋友可以参考下。代码如下:$fruits array("155::vbscript::http://www.jb51.net/list/list_114_1.htm", "1::javascript::http://www.jb51.net/list/list_3_1.htm", "2::正则表达式::http://www.jb51…

JWT.NET的使用

JWT.NET的使用 原文:JWT.NET的使用JWT是什么 JWT全称是Json Web Token,是一种用于双方之间传递安全信息的简洁的、URL安全的表述性声明规范。JWT作为一个开放的标准( RFC 7519 ),定义了一种简洁的,自包含的方法用于通信…

正在搜索需要的文件_【数澜发布-澜寻】智能内容搜索引擎,释放“机器阅读” 潜力...

4月23日,又是一年世界读书日。知识传播的重要性在这一天被无数次提起,记录、阅读成为我们 “理解”这个世界的加速通道,但在科技力量迅猛发展的当下,阅读这件事早已不再局限于人类。人工智能应用到社会中很重要的一步就是模仿人类…

学习笔记(十一)——数据库的索引碎片、计划缓存、统计信息

1.索引碎片 数据库存储本身是无序的,建立了聚集索引,会按照聚集索引物理顺序存入硬盘。既键值的逻辑顺序决定了表中相应行的物理顺序 而且在大多数的情况下,数据库写入频率远低于读取频率,索引的存在为了读取速度牺牲写入速度&…

网络软文发布软件_星浪中合网软文写出爆款汽车营销软文的特点是什么?

在移动互联网快速发展的时代,人们都是使用移动设备来获取外界信息。过去,许多广告汽车公司都专注于线下广告,但是现在他们已经将广告费用投入了移动互联网市场。移动互联网营销方法很多,例如,软文营销是一种非常强大的…

通达oa wbupload.php,关于通达OA上传附件类型限制的设置

关于上传附件类型限制的设置有些用户在使用OA系统的过程中,要求只允许上传比如后缀名为doc,xls,ppt等的附件文件。如何设置才能实现这一点呢?下面简单介绍下设置方法。1、在该路径MYOA\webroot\inc下找到配置文件oa_config.php文件…

JAVA 代码交互率低的原因分析,深入剖析Java编程中的中文问题及建议最优解决方法...

说明:本文为作者原创,作者联系地址为:josserchaiyahoo.com。由于Java编程中的中文问题是一个老生常谈的问题,在阅读了许多关于Java中文问题解决方法之后,结合作者的编程实践,我发现过去谈的许多方法都不能清…

ADC应用

数模转换(ADC)的应用笔记 智能时代,数字信号已体现在我们生活的方方面面,A/D,D/A是重要的基础。智能手机触摸信号需要转换为数字信号才能分辨触摸位置、数字去抖;打电话或者麦克风需要将模拟声信号转换为数字信号以便存…

springboot 禁用tomcat_Spring Boot 面试的十个问题

点击左上角蓝字,关注“SpringForAll社区”专注分享Spring周边技术内容用下面这些常见的面试问题为下一次 Spring Boot 面试做准备。在本文中,我们将讨论 Spring boot 中最常见的10个面试问题。现在,在就业市场上,这些问题有点棘手…

java oracle数据库连接代码,java连接oracle数据库代码实例(注释详解)

import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;public class GetOracleConnection{/** Oracle数据库连接URL*/private final static String DB_URL "jdbc:oracle:thin:1…

javascript总for of和for in的区别?

for in是ES5标准,for of是ES6标准; for in是遍历对象属性,for of是遍历对象元素。 for of兼容性还不够,移动端安卓微信浏览器貌似不支持,苹果的可以;web端IE支持也不够,chrome可以。 先说结论: 推荐在循环对象属性的时候,使用for.…

go 怎么等待所有的协程完成_理解真实世界中 Go 的并发 BUG

点击上方蓝色“Go语言中文网”关注,回复「电子书」领全套Go资料有几个学生研究归纳了go编程中的并发bugs,发表了一篇(英文)论文:《Understanding Real-World Concurrency Bugs in Go》。为你下载好了 PDF,关注公众号 Go语言中文网…

java地图图表动态亮点,可视化图表行动指南:地表最强解读来了

原标题:可视化图表行动指南:地表最强解读来了身处信息技术高速发展的时代,数据价值日益凸显,然而如何将数据更好的展示,让别人一看就懂且眼前一亮可是一门大学问。此前,小亿在广大数友的强烈要求下结合前人…

matlab cell向量匹配向量,根据2个cell格式数据中的某二列进行匹配并合并

clear allacell(9,4); % a中的第1列为样本id, 第3列为日期bcell(6,3); % b中的第1列为样本id, 第3列为日期我想根据a中的第1列对应样本id和第3列对应日期与b中的第1列对应id和第3列对应日期进行匹配合并。a{1,1}name1;a{1,2}37; a{1,3}2010/9/1; a{1,4}4.5;a{2,1}name1…

python tfidf特征变换_Spark MLlib机器学习开发指南(4)--特征提取--TF-IDF

基于最新2.2.0版本翻译本节介绍和特征一起工作的算法,大致分为以下几类:提取:从原始数据提取特征转换:缩放,转换,或者修改特征选择:从一个大的特征集合里面选择一个子集局部敏感哈希(LSH)&#…

ASP.NET MVC 使用Swagger需要注意的问题!!!

之前,一直使用的微软自带的Microsoft.AspNet.WebApi.HelpPage来作为项目的接口文档,但总感觉有些不足,就准备采用Swagger。 在项目中引用Swagger很方便,直接Nuget搜索安装Swashbuckle就可以。但是,在使用的过程中&…

小波包能量matlab,小波包分析和小波包能量介绍.doc

小波包分析和小波包能量介绍基于五次谐波和小波重构能量的配电网单相接地故障的选线方法研究*孙其东,张开如,伊利峰,宋祥民,李娅芸(山东科技大学 电气与自动化工程学院 山东 青岛 266590)摘要: 对配电网经常发生的单相接地短路故障…

分块试水--CODEVS4927 线段树练习5

模板 1 #include<stdio.h>2 #include<algorithm>3 #include<string.h>4 #include<stdlib.h>5 #include<math.h>6 //#include<bitset>7 //#include<iostream>8 using namespace std;9 10 int n,m,q;11 #define maxn 10001112 #define…