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 ...
随机推荐
- andlua,andlua发送http请求,并解析json数据
andlua发送http请求,并解析json实例 import'cjson'import 'http'--导入cjson库url = 'https://www.baidu,com'--设置urlHtt ...
- java 第六周课后作业
1.定义长度位5的整型数组,输入他们的值,用冒泡排序后输出. Scanner sc = new Scanner(System.in); int[] arr = new int[5]; for (int ...
- LeetCode 题解 | 70. 爬楼梯
假设你正在爬楼梯.需要 n 阶你才能到达楼顶. 每次你可以爬 1 或 2 个台阶.你有多少种不同的方法可以爬到楼顶呢? 注意:给定 n 是一个正整数. 示例 1: 输入: 2 输出: 2 解释: 有两 ...
- RedHat 6.5 上将系统语言修改为中文
RedHat 6.5 上将系统语言修改为中文 1.打开终端,输入su -,键入密码,获取超级用户权限. 2.输入cd /etc/sysconfig,进入设置目录. 3.输入vi i18n,进入到配置文 ...
- 【php】日期时间
一. 日期时间: a) 这是一块非常重要的内容,我们在windows当中,或者是将来要接触的定时器也好,都是需要使用到这一块内容的!二. PHP当中的日期时间: a) 时间戳:time()可以获取时间 ...
- Vulnhub DC-3靶机渗透
修改错误配置 打开了ova文件会发现,怎么也找不到DC-3的ip地址,估计是网卡出了问题. 那么就先配置下网卡. 进入上面这个页面之前按e. 将这里的ro 替换为 rw signie init=/bi ...
- 家庭版记账本app进度之编辑框组件
<EditText>中设置提示信息是用到的语句是android:hint来进行提示语句的书写. android:inputType可以将此编辑框设置为输入密码的编辑框(现实的是小黑点) a ...
- Tcl编成第二天,set与unset
代码如下: #!/usr/bin/tclsh set value "one" puts $value unset value puts $value set表示创建一个变量第一个参 ...
- 一个不错的spring 学习博客
http://www.iteye.com/blogs/subjects/spring-tittle-tattle
- Python——flask漏洞探究
python的用途是真的多,就连网站也能做,这个有点像Java的Servlet flask基础 hello world 我们先从基础的开始,在网页上打出hello world,python代码如下: ...