[MongoDB]MongoDB与JAVA结合使用CRUD
汇总:
1. [MongoDB]安装MongoDB2. [MongoDB]Mongo基本使用:3. [MongoDB]MongoDB的优缺点及与关系型数据库的比较4. [MongoDB]MongoDB与JAVA结合使用CRUD
使用起来也相当简单,由于MongoDB是类文件的数据库,所以其操作起来非常方便
首先下载相应的jar包,这里我直接使用Maven自动获取,以下为POM文件中的配置:
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.8.2</version>
</dependency>
<dependency>
<groupId>org.mongodb</groupId>
<artifactId>mongo-java-driver</artifactId>
<version>2.7.2</version>
</dependency>
一个MongoDb的jar包和Junit的jar包,即可
后面即可开始编写代码,直接在某个java类的main方法中调用即可:
public static void main(String[] args) throws Exception{
// 创建一个Mongo实例,默认使用本地"127.0.0.1", 27017
Mongo mongo1j = new Mongo();
// 使用IP+端口号创建
Mongo mongo = new Mongo("127.0.0.1", 27017);
// 得到所有数据库的名称
for(String name : mongo.getDatabaseNames()) {
System.out.println("dbName: " + name);
}
// 取得某个数据库,用于后续对数据库的操作
DB db = mongo.getDB("student");
for(String name : db.getCollectionNames()) {
System.out.println("collectionName: " + name);
}
// 取得对应的集合
DBCollection students = db.getCollection("student");
// 查询所有集合中的数据
DBCursor cur = students.find();
// 遍历集合中的所有内容
while(cur.hasNext()) {
System.out.println(cur.next());
}
System.out.println("cur.count(): " + cur.count());
System.out.println("cur.getCursorId(): " + cur.getCursorId());
System.out.println("JSON.serialize(): " + JSON.serialize(cur));
// DELETE操作
students.remove(new BasicDBObject("name", "yangjx"));
System.out.println("cur.count(): " + cur.count());
// ADD操作
DBObject student = new BasicDBObject();
student.put("name", "yangjx");
student.put("age", 55);
students.save(student);
System.out.println("cur.count(): " + cur.count());
// UPDATE操作
DBObject updateObj = new BasicDBObject();
updateObj.put("age", 30);
updateObj.put("name", "zhangGY");
updateObj.put("extra", "markHere");
students.update(new BasicDBObject("age", 30), updateObj);
System.out.println(JSON.serialize(students.find(new BasicDBObject("name", "zhangGY"))));
}
上述代码执行完成之后会打印出如下:
dbName: local
dbName: student
collectionName: colName
collectionName: student
collectionName: system.indexes
{ "_id" : { "$oid" : "555ae83a09668180fadccdeb"} , "age" : 30}
{ "_id" : { "$oid" : "555ae84009668180fadccdec"} , "name" : "zhangYC" , "age" : 29.0 , "sex" : true}
{ "_id" : { "$oid" : "555ae84709668180fadccded"} , "name" : "zhangYYQ" , "age" : 30.0 , "sex" : true}
{ "_id" : { "$oid" : "555aebdb09b332c5a188b620"} , "passwd" : "1234"}
{ "_id" : { "$oid" : "555d80d7b7a5042665b195ae"} , "name" : "yangjx" , "age" : 55}
cur.count(): 5
cur.getCursorId(): 0
JSON.serialize(): [ { "_id" : { "$oid" : "555ae83a09668180fadccdeb"} , "age" : 30} , { "_id" : { "$oid" : "555ae84009668180fadccdec"} , "name" : "zhangYC" , "age" : 29.0 , "sex" : true} , { "_id" : { "$oid" : "555ae84709668180fadccded"} , "name" : "zhangYYQ" , "age" : 30.0 , "sex" : true} , { "_id" : { "$oid" : "555aebdb09b332c5a188b620"} , "passwd" : "1234"} , { "_id" : { "$oid" : "555d80d7b7a5042665b195ae"} , "name" : "yangjx" , "age" : 55}]
cur.count(): 4
cur.count(): 5
[ { "_id" : { "$oid" : "555ae83a09668180fadccdeb"} , "age" : 30 , "name" : "zhangGY" , "extra" : "markHere"}]
参考:
http://www.cnblogs.com/hoojo/archive/2011/06/02/2068665.html
[MongoDB]MongoDB与JAVA结合使用CRUD的更多相关文章
- 4.0.3的mongodb 安装和java使用
一 整合 由于本人的码云太多太乱了,于是决定一个一个的整合到一个springboot项目里面. 附上自己的github项目地址 https://github.com/247292980/spring- ...
- MongoDB学习笔记:文档Crud Shell
MongoDB学习笔记:文档Crud Shell 文档插入 一.插入语法 db.collection.insertOne() 将单个文档插入到集合中.db.collection.insertMan ...
- [MongoDB]MongoDB的优缺点及与关系型数据库的比较
汇总: 1. [MongoDB]安装MongoDB2. [MongoDB]Mongo基本使用:3. [MongoDB]MongoDB的优缺点及与关系型数据库的比较4. [MongoDB]MongoDB ...
- Getting Started with MongoDB (MongoDB Shell Edition)
https://docs.mongodb.com/getting-started/shell/ Overview Welcome to the Getting Started with MongoDB ...
- 【MongoDB数据库】Java MongoDB CRUD Example
上一页告诉我们MongoDB 命令入门初探,本篇blog将基于上一篇blog所建立的数据库和表完毕一个简单的Java MongoDB CRUD Example.利用Java连接MongoDB数据库,并 ...
- MongoDB - MongoDB CRUD Operations
CRUD operations create, read, update, and delete documents. Create Operations Create or insert opera ...
- mongodb学习(三) 安装和基本CRUD
菜鸟啊...先吐槽一下自己 发现mongodb已经升级到2.6标准版了. 服务端最新安装方法: http://www.cnblogs.com/lzrabbit/p/3682510.html 一 准备 ...
- MongoDB分页的Java实现和分页需求的思考
前言 传统关系数据库中都提供了基于row number的分页功能,切换MongoDB后,想要实现分页,则需要修改一下思路. 传统分页思路 假设一页大小为10条.则 //page 1 1-10 //pa ...
- MongoDB 3.X JAVA基本操作
对Collection的操作 import java.util.ArrayList; import java.util.Iterator; import java.util.List; import ...
随机推荐
- mysql按日期检索数据
说明: 按日期归类, 查询2016年5月1号到5月31号每天用户注册数量 直接上源码: select DATE_FORMAT( creationTime, "%Y-%m-%d" ) ...
- LCIS
传送门 http://bestcoder.hdu.edu.cn/contests/contest_chineseproblem.php?cid=726&pid=1003 分析:这道题依然是动态 ...
- Python Day3
一.set集合 集合是一个无序的,不重复的数据组合,它的主要作用如下: 去重,把一个列表变成集合,就自动去重了 关系测试,测试两组数据之前的交集.差集.并集等关系 # 创建数值集合 list_1 = ...
- 深入理解javascript原型和闭包(5)——instanceof
又介绍一个老朋友——instanceof. 对于值类型,你可以通过typeof判断,string/number/boolean都很清楚,但是typeof在判断到引用类型的时候,返回值只有object/ ...
- Aspose.Cells 导出 excel
Aspose.Cells.Workbook book = new Aspose.Cells.Workbook(); Aspose.Cells.Worksheet sheet = book.Worksh ...
- 2015.4.24 移动端,chrome不兼容或无法运行的一些具体问题
1.table内input,把它的边框和focus边框都变成透明,在ff可行,但是chrome会有样式,怎么解决? 解决方法:border:none;outline:0; 2.如下代码,css3动画在 ...
- HTC学习笔记
添加一个属性的setter, getter 建立一个页面 <html> <head> <title>TODO supply a title</title> ...
- tyvj1193 括号序列
描述 定义如下规则序列(字符串):1.空序列是规则序列:2.如果S是规则序列,那么(S)和[S]也是规则序列:3.如果A和B都是规则序列,那么AB也是规则序列. 例如,下面的字符串都是规则 ...
- 浅谈JSON
JSON的全称是”JavaScript Object Notation”,意思是JavaScript对象表示法,它是一种基于文本,独立于语言的轻量级数据交换格式.XML也是一种数据交换格式,为什么没有 ...
- angularjs中父,子,兄之间controller值得传递
使用angularjs,发现controller间的值传递,比较麻烦的,以后几篇文章会陆续说几种方法. 一,angularjs $broadcast $emit $on的处理思想 在一个control ...