http://blog.csdn.net/qkxh320/article/details/16115671

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数据库内

对应的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<Logger> list = new ArrayList<Logger>();

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);

mongodb篇二:mongodb克隆远程数据库,去重查询的命令及对应java语句的更多相关文章

  1. Day4 数据库的建立||数据库对外查询||使用命令行来操作数据库

    ###数据库的创建 建立一个项目 先进行测试,测试新项目是否可以成功运行 创建一个PersonContrary包,并建立一个Person类实现BaseColumns借口,在此类中添加所有的表的列名,并 ...

  2. Git 使用篇二:搭建远程服务器

    一般做一个私人的项目,不希望开源的,是不会放在GitHub上的,这个时候我们需要建里一个自己的Git远程服务器,方便小组成员开发. 这里以Centos云服务器为例: 第一步 如果自己的服务器没有git ...

  3. Java连接MySQL数据库实现用户名密码的验证方法 Java语句中sql查询语句'' ""作用

    //方法一,可以验证登录,但方法不实用.package com.swift; import java.sql.Connection; import java.sql.DriverManager; im ...

  4. SQL SERVER 2008远程数据库移植到本地的方法

    https://blog.csdn.net/wuzhanwen/article/details/77449229 Winform程序或网站后台的SQL SERVER 2008放置在远程服务器上,用Mi ...

  5. plsql本机不安装数据库连接远程数据库

    用PL/SQL连接oracle数据库,不管是本地的还是远程的,一般都需要安装oracle客户端   如何达到不安装oracle客户端,又能使用PL/SQL工具?     1. oracle官网提供了i ...

  6. linux下的远程数据库(Oracle)中文乱码问题

    适用于本地客户端(PLSQL Developer )访问远程数据库时,查询结果出现的乱码,当在远程数据库上查询结果时显示正常. 1.查询远程数据库的编码: select userenv('langua ...

  7. MySQL数据库INSERT、UPDATE、DELETE以及REPLACE语句的用法详解

    本篇文章是对MySQL数据库INSERT.UPDATE.DELETE以及REPLACE语句的用法进行了详细的分析介绍,需要的朋友参考下   MySQL数据库insert和update语句引:用于操作数 ...

  8. oracle 多字段去重查询

      oracle 多字段去重查询 CreationTime--2018年6月29日15点11分 Author:Marydon 1.情景展示 需要对表BASE_MRI_DEVICE的COMPNAME.F ...

  9. 转载:MySQL数据库INSERT、UPDATE、DELETE以及REPLACE语句的用法详解

    转自:http://www.jb51.net/article/39199.htm 本篇文章是对MySQL数据库INSERT.UPDATE.DELETE以及REPLACE语句的用法进行了详细的分析介绍, ...

随机推荐

  1. jekyll bootstrap更改主题theme

    使用主题 介绍: 由于JB版本号0.2.X的主题,如今全然是模块化的.他们跟踪和单独版本号的主题包. 这让每一个人都能够自由公布和共享主题. Jekyll-Bootstrap v 0.2.x仅仅附带t ...

  2. oc中的类学习笔记1

    1.oc中的类和构造方法 NSAutoreleasePool * pool =[[NSAutoreleasePool alloc] init]; NSAutoreleasePool是一个类,alloc ...

  3. 加速Android Studio/Gradle构建

    已经使用Android Studio进行开发超过一年,随着项目的增大,依赖库的增多,构建速度越来越慢,现在最慢要6分钟才能build一个release的安装包,在网上查找资料,发现可以通过一些配置可以 ...

  4. Java基础知识强化之IO流笔记58:内存操作流

    1. 内存操作流: 用来操作处理临时存储的信息的. (1)操作字节数组: ByteArrayInputStream ByteArrayOutputStream 代码示例: package cn.itc ...

  5. Python开发笔记之正则表达式的使用

    查找正则表达式 import re re_txt = re.compile(r'(\d)*.txt') m = re_txt.search(src) if not m == None: m.group ...

  6. Java NIO Socket 非阻塞通信

    相对于非阻塞通信的复杂性,通常客户端并不需要使用非阻塞通信以提高性能,故这里只有服务端使用非阻塞通信方式实现 客户端: package com.test.client; import java.io. ...

  7. 第二种方式读取并显示HDFS中的内容

    1.讀取HDFS内容的java客戶端代碼: package Hdfs; import java.io.InputStream; import java.net.URI; import org.apac ...

  8. Bye 14 Hello 15

         打开博客.空间 窥探到大家都在写自己的2014,抬头一看日历2015已近在咫尺了,看着别人的成长(例如 今年看了多少书.做了什么项目.工资涨了多少.职位角色的变化.去了多少地方.还有一些发善 ...

  9. Android Studio快捷键快速入门

    调整,Settings->IDE Settings->Editor->Appearance->Show line numbers  显示代码行数Settings->IDE ...

  10. IOS开发中针对UIImageView的几种常用手势

    // //  ViewController.m //  05-手势 // //  Created by wanghy on 15/9/21. //  Copyright (c) 2015年 wangh ...