java mongodb修改_Java操作Mongodb数据库实现数据的增删查改功能示例

本文实例讲述了Java操作Mongodb数据库实现数据的增删查改功能。分享给大家供大家参考,具体如下:

首先,我们在windows下安装mongodb数据库,安装教程可查看前面一篇文章://www.jb51.net/article/85605.htm

代码如下:

package io.mogo;

import java.util.Map;

import org.apache.commons.lang3.StringUtils;

import com.mongodb.BasicDBObject;

import com.mongodb.DB;

import com.mongodb.DBCollection;

import com.mongodb.DBCursor;

import com.mongodb.DBObject;

import com.mongodb.Mongo;

import com.mongodb.WriteResult;

/**

* Hello world!

*

*/

public class App

{

private static final String host = "localhost";

private static final int port = 27017;

private static final String userName = "";

private static final String password = "";

private static final String dataBaseName = "test";

private static DB db;

public static void main( String[] args ) throws Exception

{

System.out.println( "Hello World!" );

connMongoDB();

find("person", "name", "xiaoming");

DBObject newObj = new BasicDBObject();

newObj.put("name", "xiaoming");

newObj.put("desc", "i am xiaoming");

update("person", "name", "xiaoming", newObj);

find("person", "name", "xiaoming");

}

public static void connMongoDB() throws Exception {

Mongo mongo = new Mongo(host, port);

db = mongo.getDB(dataBaseName);

if (!StringUtils.isEmpty(userName) || !StringUtils.isEmpty(password)) {

db.authenticate(userName, password.toCharArray());

}

}

public static void find(String tableName, String key, String value){

DBObject obj = new BasicDBObject();

obj.put(key, value);

DBCollection dbCollection = db.getCollection(tableName);

DBCursor dbCursor = dbCollection.find(obj);

while(dbCursor.hasNext()){

Map map = (Map)dbCursor.next();

System.out.println(map);

}

}

public static boolean delete(String tableName, String key, String value){

DBObject obj = new BasicDBObject();

obj.put(key, value);

DBCollection dbCollection = db.getCollection(tableName);

WriteResult result = dbCollection.remove(obj);

if(result.getN() > 0){

System.out.println("删除数据成功!");

return true;

}else{

return false;

}

}

public static boolean insert(String tableName, DBObject obj){

DBCollection dbCollection = db.getCollection(tableName);

long num = dbCollection.count();

dbCollection.insert(obj);

if(dbCollection.count() - num > 0){

System.out.println("插入数据成功!");

return true;

}else{

return false;

}

}

public static boolean update(String tableName, String key, String value, DBObject newValue){

DBObject obj = new BasicDBObject();

obj.put(key, value);

DBCollection dbCollection = db.getCollection(tableName);

DBObject oldValue = dbCollection.findOne(obj);

WriteResult result = dbCollection.update(oldValue, newValue);

if(result.getN() > 0){

System.out.println("数据更新成功!");

return true;

}else

return false;

}

}

附:完整实例代码点击此处本站下载。

希望本文所述对大家java程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值