热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Java与MongoDB数据库的CRUD(增删改查)

一、准备工作1、建立maven项目,添加所需依赖dependencygroupIdjunit/groupIdartifactIdjunit/artifactIdversion4.10/versionscopetest/scope/dependencydependencygroupIdorg.mongodb/groupI

一、准备工作

1、建立maven项目,添加所需依赖


junit
junit
4.10
test


org.mongodb
mongo-java-driver
2.11.3

当然也可以建立java
project,下载mongoDB对Java支持的驱动包,然后拷贝jar文件到lib下

2、开启mongo服务,建立测试类进行测试

二、完整源码如下:

package com.shxt.mongo;
import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.List;
import org.bson.types.ObjectId;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
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.MongoClient;
import com.mongodb.util.JSON;
 /**
  * MongDB之CRUD
  * @author 范晓东
  * @ClassName: TestMongo
  * @Version 1.0
  * @ModifiedBy
  * @Copyright shxt
  * @date 2013-9-27 下午08:21:49
  * @description
  */
public class TestMongo {
        private Mongo mg = null;
        private DB db;
        private DBCollection users;
        @Before
        public void setUp() throws UnknownHostException {
                // 创建一个MongoDB的数据库连接对象
                mg=new MongoClient("localhost", 27017);
                //验证模式登录(如果不设置验证模块,可直接登录)
                //想要登录验证模块生效,需在命令行下输入1->mongo 2->use admin 3->db.addUser("root","root123"); 4->db.auth("root","root123");
                DB admin=mg.getDB("admin");
                boolean bool =admin.authenticate("root", "root123".toCharArray());
                if (bool){
                        //login success
                        //获得一个test的数据库,如果该数据库不存在,会自动创建
                        db=mg.getDB("test");
                }
                // 获取一个聚集集合DBCollection,相当于我们的数据库表
                users = db.getCollection("users");
        }
        @Test
        public void testQuery() {
                //查询所有的数据库
                for (String name : mg.getDatabaseNames()) {
                        System.out.println("dbName: " + name);
                }
                //查询所有的聚集集合
                for (String name : db.getCollectionNames()) {
                        System.out.println("collectionName: " + name);
                }
                //查询所有的数据
                DBCursor cur = users.find();
                while (cur.hasNext()) {
                        System.out.println(cur.next());
                }
                //其它
                System.out.println(cur.count());
                System.out.println(users.count());
                System.out.println(cur.getCursorId());
                System.out.println(JSON.serialize(cur));//JSON对象转换
        }
        @Test
        public void testQuery2(){
            //根据id查询
                List list=users.find(new BasicDBObject("_id", new ObjectId("5243871a0609f38c8a7a5ccd"))).toArray();
                System.out.println(list.get(0).get("name"));
                //根据age查询,从第一条开始取,取3条数据
                BasicDBObject user = new BasicDBObject();
                user.put("age", new BasicDBObject("$gte", 20));
                DBCursor cur=users.find(user).skip(0).limit(3);
                System.out.println(cur.count());
                while (cur.hasNext()) {
                        System.out.println(cur.next());
                }
            //查询age!=25
            //users.find(new BasicDBObject("age", new BasicDBObject("$ne", 25))).toArray();
            //查询age in 25/26/27
            //users.find(new BasicDBObject("age", new BasicDBObject(QueryOperators.IN, new int[] { 25, 26, 27 }))).toArray();
            //查询age not in 25/26/27
            //users.find(new BasicDBObject("age", new BasicDBObject(QueryOperators.NIN, new int[] { 25, 26, 27 }))).toArray();
                //查询存在age的数据
            //users.find(new BasicDBObject("age", new BasicDBObject(QueryOperators.EXISTS, true))).toArray();
            //只查询age属性
            //users.find(null, new BasicDBObject("age", true)).toArray();
            //只查询一条数据,多条取第一条
            //users.findOne();
            //users.findOne(new BasicDBObject("age", 26));
            //users.findOne(new BasicDBObject("age", 26), new BasicDBObject("name", true));
            //查询age=25的数据并删除
            //users.findAndRemove(new BasicDBObject("age", 25));
            //查询age=26的数据,并且修改name的值为abc
            //users.findAndModify(new BasicDBObject("age", 26), new BasicDBObject("name", "abc"));
        }
        @Test
        public void testAdd() {
                DBObject user = new BasicDBObject();
                user.put("name", "fxd");
                user.put("age", 21);
                user.put("sex", "男");
                users.save(user);
                //查看是否添加成功
                DBCursor cur = users.find();
                while (cur.hasNext()) {
                        System.out.println(cur.next());
                }
        }
        @Test
        public void testAdd2() {
                DBObject user1 = new BasicDBObject("name","张三");
                DBObject user2 = new BasicDBObject("age",20);
                users.insert(user1,user2);
                //查看是否添加成功
                DBCursor cur = users.find();
                while (cur.hasNext()) {
                        System.out.println(cur.next());
                }
        }
        @Test
        public void testAdd3() {
                DBObject user1 = new BasicDBObject("name","张三");
                DBObject user2 = new BasicDBObject("age",20);
                List list = new ArrayList();
                list.add(user1);
                list.add(user2);
                users.insert(list);
                //查看是否添加成功
                DBCursor cur = users.find();
                while (cur.hasNext()) {
                        System.out.println(cur.next());
                }
        }
        @Test
        public void testRemove(){
            users.remove(new BasicDBObject("_id", new ObjectId("524378680609ad5717421c6a")));
            //users.remove(new BasicDBObject("age", new BasicDBObject("$gte", 24)));
        }
        @Test
        public void update(){
                 //=update users set age=17 where name='fxd';
                 users.update(
                          new BasicDBObject("name","fxd"),//new BasicDBObject().append("name","fxd"),
                          new BasicDBObject("$set" ,new BasicDBObject("age",17)),
                  false,//如果users中不存在age字段,是否更新,false表示不更新
                  false//只修改第一条,true表示修改多条
                 );
        }
        @Test
        public void update2(){
                 //批量修改,也可以用users.update(),把第四个参数改为true即可
                 //=update users set age=age+10 where name='fxd';
                 users.updateMulti(
                          new BasicDBObject().append("name","fxd"),
                          new BasicDBObject("$inc",new BasicDBObject("age", 10))
                );
        }
        @After
        public void tearDown() {
                if (mg != null) {
                        if (db != null) {
                                // 结束Mongo数据库的事务请求
                                try {
                                        db.requestDone();
                                } catch (Exception e) {
                                        e.printStackTrace();
                                }
                        }
                        try {
                                mg.close();
                        } catch (Exception e) {
                                e.printStackTrace();
                        }
                        mg = null;
                        db = null;
                }
        }
}



推荐阅读
  • MongoDB核心概念详解
    本文介绍了NoSQL数据库的概念及其应用场景,重点解析了MongoDB的基本特性、数据结构以及常用操作。MongoDB是一个高性能、高可用且易于扩展的文档数据库系统。 ... [详细]
  • 本文介绍了如何使用Node.js通过两种不同的方法连接MongoDB数据库,包括使用MongoClient对象和连接字符串的方法。每种方法都有其特点和适用场景,适合不同需求的开发者。 ... [详细]
  • Vue CLI 基础入门指南
    本文详细介绍了 Vue CLI 的基础使用方法,包括环境搭建、项目创建、常见配置及路由管理等内容,适合初学者快速掌握 Vue 开发环境。 ... [详细]
  • 本文探讨了如何在 Spring MVC 框架下,通过自定义注解和拦截器机制来实现细粒度的权限管理功能。 ... [详细]
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • 近期尝试从www.hub.sciverse.com网站通过编程手段获取数据时遇到问题,起初尝试使用WebBrowser控件进行数据抓取,但发现使用GET方法翻页时,返回的HTML代码始终相同。进一步探究后了解到,该网站的数据是通过Ajax异步加载的,可通过HTTP查看详细的JSON响应。 ... [详细]
  • Jupyter Notebook多语言环境搭建指南
    本文详细介绍了如何在Linux环境下为Jupyter Notebook配置Python、Python3、R及Go四种编程语言的环境,包括必要的软件安装和配置步骤。 ... [详细]
  • 小编给大家分享一下Vue3中如何提高开发效率,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获, ... [详细]
  • protobuf 使用心得:解析与编码陷阱
    本文记录了一次在广告系统中使用protobuf进行数据交换时遇到的问题及其解决过程。通过这次经历,我们将探讨protobuf的特性和编码机制,帮助开发者避免类似的陷阱。 ... [详细]
  • 实践指南:使用Express、Create React App与MongoDB搭建React开发环境
    本文详细介绍了如何利用Express、Create React App和MongoDB构建一个高效的React应用开发环境,旨在为开发者提供一套完整的解决方案,包括环境搭建、数据模拟及前后端交互。 ... [详细]
  • 第一步java代码条件匹配与之对应的mongo数据查询第二步:java代码分组查询与之所对应的mongodb中sheel与所得出的表点击某个_id字段进入,所得出的图表为第三步:在 ... [详细]
  • 在OpenShift上部署基于MongoDB和Node.js的多层应用程序
    本文档详细介绍了如何在OpenShift 4.x环境中部署一个包含MongoDB数据库和Node.js后端及前端的多层应用程序。通过逐步指导,读者可以轻松完成整个部署过程。 ... [详细]
  • MySQL Decimal 类型的最大值解析及其在数据处理中的应用艺术
    在关系型数据库中,表的设计与SQL语句的编写对性能的影响至关重要,甚至可占到90%以上。本文将重点探讨MySQL中Decimal类型的最大值及其在数据处理中的应用技巧,通过实例分析和优化建议,帮助读者深入理解并掌握这一重要知识点。 ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • ### 优化后的摘要本学习指南旨在帮助读者全面掌握 Bootstrap 前端框架的核心知识点与实战技巧。内容涵盖基础入门、核心功能和高级应用。第一章通过一个简单的“Hello World”示例,介绍 Bootstrap 的基本用法和快速上手方法。第二章深入探讨 Bootstrap 与 JSP 集成的细节,揭示两者结合的优势和应用场景。第三章则进一步讲解 Bootstrap 的高级特性,如响应式设计和组件定制,为开发者提供全方位的技术支持。 ... [详细]
author-avatar
我有岁月619
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有