【MongoDB数据库】Java MongoDB CRUD Example

上一篇我们讲了MongoDB 的命令入门初探,本篇blog将基于上一篇blog所建立的数据库和表完毕一个简单的Java MongoDB CRUD Example,利用Java连接MongoDB数据库。并实现创建数据库、获取表、遍历表中的对象、对表中对象进行CRUD操作等例程。

1、下载MongoDB Java 支持驱动包

【gitHub下载地址】https://github.com/mongodb/mongo-java-driver/downloads

2、建立Javaproject,并导入jar包

3、连接本地数据库server

在控制面板中开启Mongodb服务,详细操作可參考【MongoDB数据库】怎样安装、配置MongoDB

		try {
			mongo = new MongoClient("localhost", 27017);// 保证MongoDB服务已经启动
			db = mongo.getDB("andyDB");// 获取到数据库
		} catch (UnknownHostException e) {
			e.printStackTrace();
		}

3、遍历全部的数据库名

public class DBConnection extends TestCase {

	private MongoClient mongo;
	private DB db ;

	@Override
	protected void setUp() throws Exception {
		// TODO Auto-generated method stub
		super.setUp();
		try {
			mongo = new MongoClient("localhost", 27017);// 保证MongoDB服务已经启动
			db = mongo.getDB("andyDB");// 获取到数据库andyDB
		} catch (UnknownHostException e) {
			e.printStackTrace();
		}
	}

	public void testGetAllDB() {
		List<String> dbs = mongo.getDatabaseNames();// 获取到全部的数据库名
		for (String dbname : dbs) {
			System.out.println(dbname);
		}
	}
}

4、获取到指定数据库

       DB db = mongo.getDB("andyDB");// 获取到数据库

5、遍历数据库中全部的表名

在DBConnection測试类中加入例如以下測试方法就可以:

	public void testGetAllTables() {
		Set<String> tables = db.getCollectionNames();
		for (String coll : tables) {
			System.out.println(coll);
		}
	}

6、获取到指定的表

DBCollection table = db.getCollection("person");

7、遍历表中全部的对象

public void testFindAll(){
		DBCollection table = db.getCollection("person");
		DBCursor dbCursor = table.find();
		while(dbCursor.hasNext()){
			DBObject dbObject = dbCursor.next();
			//打印该对象的特定字段信息
			System.out.println("name:"+	dbObject.get("name")+",age:"+dbObject.get("age"));
			//打印该对象的全部信息
			System.out.println(dbObject);
		}
	}

Console窗体打印消息:

name:jack,age:50.0

{ "_id" : { "$oid" : "537761da2c82bf816b34e6cf"} , "name" : "jack" , "age" : 50.0}

name:小王,age:24

{ "_id" : { "$oid" : "53777096d67d552056ab8916"} , "name" : "小王" , "age" : 24}

8、保存对象

1)保存对象方法一

	public void testSave() {
		DBCollection table = db.getCollection("person");
		BasicDBObject document = new BasicDBObject();
		document.put("name", "小郭");// 能直接插入汉字
		document.put("age", 24);//"age"相应的值是int型
		table.insert(document);
	}

在mongodb shell中使用命令查看数据

> db.person.find()

{ "_id" : ObjectId("537761da2c82bf816b34e6cf"), "name" : "jack", "age" : 50 }

{ "_id" : ObjectId("53777096d67d552056ab8916"), "name" : "小王", "age" : 24 }

{ "_id" : ObjectId("5377712cd67d84f62c65c4f6"), "name" : "小郭", "age" : 24 }

2)保存对象方法二

	public void testSave2() {
		DBCollection table = db.getCollection("person");
		BasicDBObject document = new BasicDBObject();//能够加入多个字段
		document.put("name", "小张");// 能直接插入汉字
		document.put("password", "xiaozhang");// 多加入一个字段也是能够的,由于MongoDB保存的是对象。
		document.put("age", "23");//"age"相应的值是String
		table.insert(document);
	}

在mongodb shell中使用命令查看数据

> db.person.find()

{ "_id" : ObjectId("537761da2c82bf816b34e6cf"), "name" : "jack", "age" : 50 }

{ "_id" : ObjectId("53777096d67d552056ab8916"), "name" : "小王", "age" : 24 }

{ "_id" : ObjectId("5377712cd67d84f62c65c4f6"), "name" : "小郭", "age" : 24 }

{ "_id" : ObjectId("53777230d67dfe576de5079a"), "name" : "小张", "password" : "xiaozhang", "age" : "23" }

3)保存对象方法三通过加入Map集合的方式加入数据到BasicDBObject

	public void testSave3(){
		DBCollection table = db.getCollection("person");

		Map<String,Object> maps = new HashMap<String,Object>();
		maps.put("name", "小李");
		maps.put("password", "xiaozhang");
		maps.put("age", 24);

		BasicDBObject document = new BasicDBObject(maps);//这样加入后。对象里的字段是无序的。
		table.insert(document);
	}

在mongodb shell中使用命令查看数据

> db.person.find()

{ "_id" : ObjectId("537761da2c82bf816b34e6cf"), "name" : "jack", "age" : 50 }

{ "_id" : ObjectId("53777096d67d552056ab8916"), "name" : "小王", "age" : 24 }

{ "_id" : ObjectId("5377712cd67d84f62c65c4f6"), "name" : "小郭", "age" : 24 }

{ "_id" : ObjectId("53777230d67dfe576de5079a"), "name" : "小张", "password" : "xiaozhang", "age" : "23" }

{ "_id" : ObjectId("537772e9d67df098a26d79a6"), "age" : 24, "name" : "小李", "password" : "xiaozhang" }

9、更新对象

我们能够结合【mongodb shell命令】db.person.update({name:"小李"},{$set:{password:"hello"}})来理解Java是怎样操作对象来更新的。{name:"小李"}是一个BasicDBObject。{$set:{password:"hello"}也是一个BasicDBObject。这样理解的话。你就会认为mongodb
shell命令操作和Java操作非常相似。

	public void testUpdate() {
		DBCollection table = db.getCollection("person");
		BasicDBObject query = new BasicDBObject();
		query.put("name", "小张");

		BasicDBObject newDocument = new BasicDBObject();
		newDocument.put("age", 23);

		BasicDBObject updateObj = new BasicDBObject();
		updateObj.put("$set", newDocument);
		table.update(query, updateObj);
	}

	// 命令操作:db.person.update({name:"小李"},{$set:{password:"hello"}})
	public void testUpdate2() {
		DBCollection table = db.getCollection("person");
		BasicDBObject query = new BasicDBObject("name", "小张");
		BasicDBObject newDocument = new BasicDBObject("age", 24);
		BasicDBObject updateObj = new BasicDBObject("$set", newDocument);
		table.update(query, updateObj);
	}

10、删除对象

可參考db.users.remove({name:"小李"})命令来理解Java操作对象

	public void testDelete(){
		DBCollection table = db.getCollection("person");
		BasicDBObject query = new BasicDBObject("name", "小李");
		table.remove(query);
	}
	

11、參考

Java + MongoDB Hello World Example(推荐)

12、你可能感兴趣

【MongoDB数据库】怎样安装、配置MongoDB

【MongoDB数据库】MongoDB 命令入门初探

转载请注明出处:http://blog.csdn.net/andie_guo/article/details/26098331,谢谢!

时间: 2024-10-23 05:19:25

【MongoDB数据库】Java MongoDB CRUD Example的相关文章

【MongoDB数据库】MongoDB 命令入门初探

MongoDB是一款NoSql数据库,使用了"面向集合"(Collection-Oriented)原理,意思是数据被分组存储在数据集中,被称为一个集合(Collection).每个集合(Collection)在数据库中都有一个唯一的标识名,并且可以包含无限数目的对象(BasicDBObject). 集合(Collection)的概念类似关系型数据库(RDBMS)里的表(table),对象(BasicDBObject)的概念类似于RDBMS中表的一条数据,关系数据库里插入一条数据等价于在

nodejs操作mongodb数据库(mongodb)

1.增加 var MongoClient = require("mongodb").MongoClient; var DB_URL = "mongodb://localhost:27017/chm"; function insertData(db) { var devices = db.collection('vip'); var data = {"name":"node","age":22,"a

【MongoDB数据库】怎样安装、配置MongoDB

本blog以最简洁的方式记录了博主在折腾MongoDB过程中点点滴滴,当中包含下载MongoDB.配置环境变量.怎样启动MongoDBserver.怎样连接MongoDBserver以及怎样连接MongoDBserver等. 1.下载 MongoDB 官方下载地址:http://www.mongodb.org/downloads 本机是Windows 7 32位.故下载的是mongodb-win32-i386-2.6.1.zip,兴许例程均是基于该版本号数据库. 2.配置环境变量 解压mongo

node.js操作数据库之MongoDB+mongoose篇

前言 node.js的出现,使得用前端语法(javascript)开发后台服务成为可能,越来越多的前端因此因此接触后端,甚至转向全栈发展.后端开发少不了数据库的操作.MongoDB是一个基于分布式文件存储的开源数据库系统.本文为大家详细介绍了如何用node.js + mongoose 玩转MongoDB.希望能帮到有需要的人. 由于我用Mac开发,以下所有操作都是在Mac下进行. 一. 环境搭建 安装Node.js 有 node 环境的可以跳过. nodejs官网提供了 macOS 安装包,直接

[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> &l

Mongodb系列- java客户端简单使用(CRUD)

Mongodb提供了很多的客户端: shell,python, java, node.js...等等. 以 java 为例实现简单的增删改查 在这里我们先封装一个mongodb管理类: import java.util.ArrayList; import java.util.List; import java.util.Map; import org.bson.Document; import org.slf4j.Logger; import org.slf4j.LoggerFactory; i

java操作MongoDB数据库

1.如何启动MongoDB数据库? 如图所示:安装好MongoDB之后,文件夹显示如下: MongoDB默认开启27017端口,打开浏览器,输入http://localhost:27017/,显示如下: 启动数据库步骤: (1)cd d:\beiyongkaifa\mongodb\bin (2)输入:mongod --dbpath=D:\beiyongkaifa\mongodb\db,回车.如图1所示: (3)启动另一个cmd,cd d:\beiyongkaifa\mongodb\bin (4)

java连接MongoDB数据库

这段时间尝试了一下MongoDB,感觉十分易用,方便,相比关系型的数据库来说优势也很大,于是尝试了下使用java连接MongoDB,并进行了 基本的增删改查操作. 首先先在控制台中连接数据库,查看数据库有几个表. 现在,新建一个maven工程,pom.xml中的依赖如下: <!-- WICKET DEPENDENCIES --> <dependency> <groupId>org.apache.wicket</groupId> <artifactId&

不使用spring的情况下原生java代码两种方式操作mongodb数据库

由于更改了mongodb3.0数据库的密码,导致这几天storm组对数据进行处理的时候,一直在报mongodb数据库连接不上的异常.   主要原因实际上是和mongodb本身无关的,因为他们改的是配置文件的密码,而实际上这个密码在代码中根本就没有使用,他们在代码中已经把用户验证信息写死.   在协助他们解决这个问题的时候,我看到他们代码中在和mongodb数据库交互时使用了已经不被建议使用的方法,于是便抽时间尝试了一下另一种被建议的方式实现各功能.   当然了,生产环境中用的是mongodb集群