mongodb篇二:mongodb克隆远程数据库,去重查询的命令及对应java语句
2014-09-11 12:00
671 查看
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);
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 JAVA API高级查询示例(对应于上一篇)
- Oracle中查询当前数据库中的所有表空间和对应的数据文件语句命令
- Oracle中查询当前数据库中的所有表空间和对应的数据文件语句命令
- mongodb的java driver执行“原生查询”语句
- mongoDB Java的aggregate查询结果的遍历不停向mongoDB发送命令
- mongodb查询不区分大小写 java代码和查询命令
- MongoDB下的查询操作(与上篇文章java api查询操作对应)
- MongoDB JAVA API高级查询示例(对应于上一篇)
- MongoDB java api for 插入和单collection基本查询使用示例
- 第四章 查询语句:MongoDb VS MySql 4.1
- 第四章 查询语句:MongoDb VS MySql 4.2
- Java26日通—第 1 天 Oracle基本命令与简单查询
- 查询一个表中所有id字段在另一个表中对应值的SQL语句怎么写?
- 跟我学Java26日通-第1天 Oracle基本命令与简单查询
- MyBatis之SQL语句映射文件增删改查和Java参数如何对应
- [转]windows下查询端口对应应用进程的命令
- 对sql查询语句组合查询的通用实现算法(c++版,java版)
- SQL命令查询视图定义语句
- JAVA连接MYSQL,查询 ,添加,删除,语句
- mysql查询语句优化命令mysql explain