MongoDB学习(四):通过Java使用MongoDB
环境配置
在Java项目中使用MongoDB,需要在项目中引入mongo.jar这个包。下载地址:下载
请尽量下载较新的版本,本文用的是2.10.1。
连接MongoDB
public synchronized static DB getDBConnection() throws UnknownHostException{
if(db == null){
MongoClient client = new MongoClient(DB_SERVER_IP, DBSERVER_PORT);
db = client.getDB(DB_NAME);
System.out.println("GET DBCONNECTION SUCCESSFUL");
}
return db;
}
其中IP和PORT分别是数据库服务端的IP和端口号。
创建集合
public static DBCollection getCollection(String colName){
col = db.getCollection(colName);
if(col == null){
col = db.createCollection(colName, null);
}
return col;
}
插入文档
插入数据有4中方式可选:1.利用DBObjcet,2.利用DBObjectBuilder, 3.先创建Map对象,再用Map对象构造DBObject,4.直接通过json对象创建。
这里我们主要介绍第一种方式——利用DBObject插入。DBObject是一个接口,继承自BSONObject,是可被存入数据库的一个键值的Map。这里我们使用它的基本实现:BasicDBObject。
public static void insert(){
DBCollection col = getCollection("myCollection1");
if(col != null){
DBObject o = new BasicDBObject();
o.put("name", "Z");
o.put("gender", "f");
o.put("age", 1);
col.insert(o);
}
}
另外,你也可以使用BasicDBObject提供的append()函数,来为对象插入键值对。
当你需要批量插入数据时,可以使用DBCollection.insert(List<DBObject> list);
查询文档
可以通过DBCollection.find()来查询集合中的文档。该函数返回一个游标DBCursor。通过对其迭代输出,就可以得到文档组。或者是通过DBCursor.toArray()直接转成DBObject的列表List<DBObject>。代码如下:
public static void search(){
DBCollection col = getCollection("myCollection1");
if(col != null){
DBCursor cursor = col.find();
while(cursor.hasNext()){
DBObject o = cursor.next();
System.out.println(o);
}
}
}
public static void search(){
DBCollection col = getCollection("myCollection1");
if(col != null){
List<DBObject> list = col.find().toArray();
}
}
当然,也可以设置查询条件,并对输出结果的字段进行限制:
public static void search2(){
DBCollection col = getCollection("myCollection1");
if(col != null){
//查询条件
DBObject query = new BasicDBObject();
query.put("gender", "m");
//输出结果是否有要输出某个字段。0表示不输出,1表示只输出该字段
DBObject field = new BasicDBObject();
field.put("name", 1);
DBCursor cursor = col.find(query,field);
while(cursor.hasNext()){
System.out.println(cursor.next());
}
}
}
上述代码就表示查询性别为m的全部文档,并输出其姓名。
较复杂的条件查询:
public static void search2(){
DBCollection col = getCollection("myCollection1");
if(col != null){
//查询条件
DBObject query = new BasicDBObject();
DBObject o = new BasicDBObject("$lt",24).append("$gt", 21);
query.put("age", o);
DBCursor cursor = col.find(query);
while(cursor.hasNext()){
System.out.println(cursor.next());
}
}
}
这里我们筛选的是年龄小于24且大于21的全部文档。
更新文档
public static void update1(){
DBCollection col = getCollection("myCollection1");
if(col != null){
//查询条件
DBObject query = new BasicDBObject();
query.put("name", "A");
//用来替换的文档
DBObject newObject = new BasicDBObject();
newObject.put("name", "A1");
col.update(query, newObject);
}
}
这里我们将name这个字段等于A的文档替换成了name字段为A1的值,注意的是,新的文档将不包含旧文档的其他字段,是真正意义上的两个文档的替换,而非替换相同字段!另外一点需要注意的是,该方法只替换第一条符合查询条件的文档。因为multi的默认值为false,可以通过设置这个值为true来修改多条。
findAndModity(DBObject query, DBObject fields, DBObject sort, boolean remove, DBObject update,boolean returnNew,boolean upsert)也提供了类似的功能。
query - query to match
fields - fields to be returned
sort - sort to apply before picking first document
remove - if true, document found will be removed
update - update to apply
returnNew - if true, the updated document is returned, otherwise the old document is returned (or it would be lost forever)upsert - do upsert (insert if document not present)
删除文档
删除指定的一个文档:
public static void remove1(){
DBCollection col = getCollection("myCollection1");
if(col != null){
DBObject o = col.findOne();
col.remove(o);
}
}
删除符合某条件的文档:
public static void remove2(){
DBCollection col = getCollection("myCollection1");
if(col != null){
//条件
DBObject query = new BasicDBObject();
query.put("name", "A1");
col.remove(query);
}
}
会删除符合条件的全部文档。
如需要删除集合下的全部文档时,可结合DBCursor实现。
参考:
API文档:http://api.mongodb.org/java/2.10.1/
其他资料:菜鸟教程
http://blog.csdn.net/hx_uestc/article/details/7620938
MongoDB学习(四):通过Java使用MongoDB的更多相关文章
- MongoDB学习:(二)MongoDB简单使用
MongoDB学习:(二)MongoDB简单使用 MongoDB使用: 执行mongodb的操作之前,我们需要运行命令,来进入操作命令界面 >mongo 提示该错误,说明我们系统缺少一个补丁,该 ...
- MongoDB学习:(一)MongoDB安装
MongoDB学习:(一)MongoDB安装 MongoDB介绍: 直接百科了: MongoDB安装: 1:下载安装: MongoDB安装:https://www.mongodb.com/do ...
- MongoDB学习笔记—Linux下搭建MongoDB环境
1.MongoDB简单说明 a MongoDB是由C++语言编写的一个基于分布式文件存储的开源数据库系统,它的目的在于为WEB应用提供可扩展的高性能数据存储解决方案. b MongoDB是一个介于关系 ...
- Mongodb入门并使用java操作Mongodb
转载请注意出处:http://blog.csdn.net/zcm101 最近在学习NoSql,先从Mongodb入手,把最近学习的总结下. Mongodb下载安装 Mongodb的下载安装就不详细说了 ...
- MongoDB(六)java操作mongodb增删改查
java操作mysql数据库的代码我们已经了如指掌了.增删改查,java对mongodb数据库也是类似的操作,先是数据库连接.再是进行操作. 首先我们进入进入admin数据库.然后建立自己的数据库te ...
- MongoDB 学习笔记(三) MongoDB (replica set) 集群配置
MongoDB Replica Sets的结构类似于以集群,完全可以把他当成一个集群,因为他确实与集群实现的作用是一样的:如果其中一个节点出现故障,其他的节点会马上将业务接管过来.而无需停机操作 Mo ...
- [linux][MongoDB] mongodb学习(一):MongoDB安装、管理工具、
参考原文:http://www.cnblogs.com/kaituorensheng/p/5118226.html linux安装完美实现! 1. mongoDB安装.启动.关闭 1.1 下载安装包 ...
- MongoDB学习1:认识文档数据库MongoDB
1. 关于MongoDB 什么是MongoDB 一个以JSON为数据模型的文档数据库 为什么叫文档数据库 文档来自于"JSON Document",并非我们一般理解的pdf,wor ...
- [转载]MongoDB学习 (四):创建、读取、更新、删除(CRUD)快速入门
本文介绍数据库的4个基本操作:创建.读取.更新和删除(CRUD). 接下来的数据库操作演示,我们使用MongoDB自带简洁但功能强大的JavaScript shell,MongoDB shell是一个 ...
- 【MongoDB学习之五】Java中使用MongoDB
环境 MongoDB 3.0 CentOS6.5_x64 相关jar:mongo-java-driver-3.0.0.jar package com.mongodb; import java.util ...
随机推荐
- 计算机网络学习笔记NO.2 物理层
2.1 基本概念 2.1.1 物理层概念 物理层解决如何在连接各种计算机的传输媒体上传输数据比特流,而不是指具体的传输媒体. 物理层主要任务:确定与传输媒体接口有关的一些特性(定义标准) 机械特性:定 ...
- template_共享模板
方法: 定义一个基本框架html文件 举例:定义{标题.内容.页尾}区块 定义相应的html文件实现区块的具体样式或内容 定义具体静态网页html文件时调用这些区块html文件, 实现公共元 ...
- spark 大杂烩
累加器 val dataRdd = sc.makeRDD(List(1, 2, 3, 4), 2) var sum = 0 //累加器可以收集driver和各个excuter中累加的结果 //如果此处 ...
- Atlas运行时资源不足报错 -bash: fork: retry: 资源暂时不可用 Out of system resources
目的:运行Atlas并使用Azkaban执行操作任务 环境:Centos 6 内存大小:12G 启动下面的任务后还剩内存将近5G 问题: 当mysql_to_hdfs_db和其他job同时运行时集群很 ...
- floyd三重循环最外层为什么一定是K
Floyd算法为什么把k放在最外层? - 知乎 https://www.zhihu.com/question/30955032高票答案: 简单地总结一下:K没放在最外面一定是错的,但是在某些数据比较水 ...
- Docker php安装扩展步骤详解
前言 此篇,主要是演示docker-php-source , docker-php-ext-install ,docker-php-enable-docker-configure 这四个命令到底是用来 ...
- 数据结构和算法(Golang实现)(13)常见数据结构-可变长数组
可变长数组 因为数组大小是固定的,当数据元素特别多时,固定的数组无法储存这么多的值,所以可变长数组出现了,这也是一种数据结构.在Golang语言中,可变长数组被内置在语言里面:切片slice. sli ...
- Java学习成长第一集
由于最近所在项目组的项目临近结尾,所以有时间对自己近来的学习做个总结.不得不说,程序员不学习就退步这句话是真的很让人信服!自己入行将近一年的时间,所学的就是Java开发的专业,很羞愧的是现在的自己能力 ...
- AJ学IOS(48)多线程网络之多线程简单了解
AJ分享,必须精品 一:进程和线程 1:什么是进程 进程是指在系统中正在运行的一个应用程序 每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内. 比如同时打开QQ.Xcode,系统就会分 ...
- SaaS、PaaS、IaaS的含义与区别
先上个图,直观的了解一下 云计算有SPI,即SaaS.PaaS和IaaS三大服务模式. PaaS和IaaS源于SaaS SaaS Software as a Service 软件即服务,提供给客户的服 ...