由于更改了mongodb3.0数据库的密码,导致这几天storm组对数据进行处理的时候,一直在报mongodb数据库连接不上的异常。

 

主要原因实际上是和mongodb本身无关的,因为他们改的是配置文件的密码,而实际上这个密码在代码中根本就没有使用,他们在代码中已经把用户验证信息写死。

 

在协助他们解决这个问题的时候,我看到他们代码中在和mongodb数据库交互时使用了已经不被建议使用的方法,于是便抽时间尝试了一下另一种被建议的方式实现各功能。

 

当然了,生产环境中用的是mongodb集群,验证时的写法和单机时会略有不同,我这里就只拿单机试验。

 

使用原生的Java代码操作mongodb数据库,就不需要和spring集成的那些jar包,只用到了mongodb-java-driver3.0.3.jar,代码如下,一些需要注意的地方也都写在注释中:

 

[java] view
plain
 copy

  1. package monAndMysql;
  2. import java.util.ArrayList;
  3. import java.util.Date;
  4. import java.util.List;
  5. import java.util.Set;
  6. import org.bson.BsonDocument;
  7. import org.bson.BsonString;
  8. import org.bson.Document;
  9. import org.bson.conversions.Bson;
  10. import com.mongodb.BasicDBObject;
  11. import com.mongodb.DB;
  12. import com.mongodb.DBCollection;
  13. import com.mongodb.DBCursor;
  14. import com.mongodb.DBObject;
  15. import com.mongodb.MongoClient;
  16. import com.mongodb.MongoCredential;
  17. import com.mongodb.ServerAddress;
  18. import com.mongodb.client.FindIterable;
  19. import com.mongodb.client.MongoCollection;
  20. import com.mongodb.client.MongoCursor;
  21. import com.mongodb.client.MongoDatabase;
  22. import com.mongodb.client.model.Filters;
  23. /**
  24. * mongodb和mysql性能测试
  25. *
  26. * @author tuzongxun123
  27. *
  28. */
  29. public class MonAndMysqlTest {
  30. public static void main(String[] args) {
  31. mongodbTest();
  32. }
  33. public static void mongodbTest() {
  34. ServerAddress sa = new ServerAddress("192.168.0.7", 27017);
  35. List<MongoCredential> mongoCredentialList = newArrayList<MongoCredential>();
  36. // java代码连接mongodb3.0数据库验证,userName,dbName,password
  37. mongoCredentialList.add(MongoCredential.createMongoCRCredential(
  38. "admin", "admin", "123456".toCharArray()));
  39. MongoClient client = new MongoClient(sa, mongoCredentialList);
  40. // 第一种方式
  41. // 第一种方式获取db,该方法已经不建议使用
  42. DB mongoDB = client.getDB("mongoTest1");
  43. DBCollection collection1 = mongoDB.getCollection("userTest1");
  44. // 这里的数据类型是dbobject
  45. DBObject document1 = new BasicDBObject();
  46. document1.put("name", "mongoTest1");
  47. document1.put("createTime", new Date().getTime());
  48. // 插入数据
  49. collection1.insert(document1);
  50. // 查询数据
  51. DBCursor cursor1 = collection1.find();
  52. System.out.println("第一种方式插入数据的结果:");
  53. while (cursor1.hasNext()) {
  54. DBObject object = cursor1.next();
  55. Set<String> keySet = object.keySet();
  56. for (String key : keySet) {
  57. System.out.println(key + ":" + object.get(key));
  58. }
  59. }
  60. // 更改数据
  61. DBObject query = new BasicDBObject();
  62. DBObject update = new BasicDBObject();
  63. query.put("name", "mongoTest1");
  64. update.put("$set", new BasicDBObject("name", "update1"));
  65. collection1.update(query, update);
  66. System.out
  67. .println("--------------------------------------------------------------------------------------");
  68. System.out.println("第一种方式修改数据的结果:");
  69. DBCursor cursor11 = collection1.find();
  70. while (cursor11.hasNext()) {
  71. DBObject object = cursor11.next();
  72. Set<String> keySet = object.keySet();
  73. for (String key : keySet) {
  74. System.out.println(key + ":" + object.get(key));
  75. }
  76. }
  77. // 删除数据
  78. DBObject query1 = new BasicDBObject();
  79. query1.put("name", "update1");
  80. collection1.remove(query1);
  81. System.out
  82. .println("--------------------------------------------------------------------------------------");
  83. System.out.println("第一种方式删除数据的结果:");
  84. DBCursor cursor12 = collection1.find();
  85. while (cursor12.hasNext()) {
  86. DBObject object = cursor12.next();
  87. Set<String> keySet = object.keySet();
  88. for (String key : keySet) {
  89. System.out.println(key + ":" + object.get(key));
  90. }
  91. }
  92. // 第二种方式
  93. System.out
  94. .println("****************************************************************************");
  95. // 第二种方式获取db及插入数据和查询操作。推荐方式
  96. MongoDatabase database = client.getDatabase("mongoTest2");
  97. // 注意这里的数据类型是document
  98. Document document2 = new Document();
  99. document2.put("name", "mongoTest2");
  100. document2.put("createTime", new Date().getTime());
  101. MongoCollection collection2 = database.getCollection("userTest2");
  102. // 插入数据
  103. collection2.insertOne(document2);
  104. // 查询数据,注意这里直接查询出的结果不是游标,还需要转换
  105. FindIterable<Document> findIterable = collection2.find();
  106. MongoCursor<Document> cursor2 = findIterable.iterator();
  107. System.out.println("第二种方式插入数据的结果:");
  108. while (cursor2.hasNext()) {
  109. Document document = cursor2.next();
  110. Set<String> keySet = document.keySet();
  111. for (String key : keySet) {
  112. System.out.println(key + ":" + document.get(key));
  113. }
  114. }
  115. // 更改数据
  116. Bson filter = Filters.eq("name", "mongoTest2");
  117. BsonDocument update2 = new BsonDocument();
  118. update2.put("$set", new BsonDocument("name", new BsonString("update2")));
  119. collection2.updateOne(filter, update2);
  120. System.out
  121. .println("--------------------------------------------------------------------------------------");
  122. MongoCursor<Document> cursor21 = findIterable.iterator();
  123. System.out.println("第二种方式更改数据的结果:");
  124. while (cursor21.hasNext()) {
  125. Document document = cursor21.next();
  126. Set<String> keySet = document.keySet();
  127. for (String key : keySet) {
  128. System.out.println(key + ":" + document.get(key));
  129. }
  130. }
  131. // 删除数据
  132. Bson filter2 = Filters.eq("name", "update2");
  133. collection2.deleteOne(filter2);
  134. System.out
  135. .println("--------------------------------------------------------------------------------------");
  136. MongoCursor<Document> cursor22 = findIterable.iterator();
  137. System.out.println("第二种方式删除数据的结果:");
  138. while (cursor22.hasNext()) {
  139. Document document = cursor22.next();
  140. Set<String> keySet = document.keySet();
  141. for (String key : keySet) {
  142. System.out.println(key + ":" + document.get(key));
  143. }
  144. }
  145. // 关闭数据库连接
  146. client.close();
  147. }
  148. }

执行main方法后,控制台打印结果如下图所示,证明操作都是没有问题的:

不使用spring的情况下用java原生代码操作mongodb数据库的两种方式的更多相关文章

  1. JAVA发送http GET/POST请求的两种方式+JAVA http 请求手动配置代理

    java发送http get请求,有两种方式. 第一种用URLConnection: public static String get(String url) throws IOException { ...

  2. java中读取配置文件ResourceBundle和Properties两种方式比较

    今天在开发的时候,需要把一些信息放到配置文件中,方便后续的修改,注意到用的是ResourceBundle读取配置文件的方式,记得之前也见过使用Properties的方式,就比较好奇这两种方式的区别,网 ...

  3. 依赖Spring的情况下,Java Web项目如何在启动时加载数据库中的数据?

    原文:https://blog.csdn.net/u012345283/article/details/39558537 原文:https://blog.csdn.net/wandrong/artic ...

  4. windows下配置tomcat服务器的jvm内存大小的两种方式

    难得遇到一次java堆内存溢出(心里想着,终于可以来一次jvm性能优化了$$) 先看下报错信息, java.lang.OutOfMemoryError: GC overhead limit excee ...

  5. Linux下chkconfig命令详解即添加服务以及两种方式启动关闭系统服务

    The command chkconfig is no longer available in Ubuntu.The equivalent command to chkconfig is update ...

  6. java操作excel常用的两种方式

    Excel是我们平时工作中比较常用的用于存储二维表数据的,JAVA也可以直接对Excel进行操作,在这篇博客中将为大家介绍两种操作Excel的方式,分别为:jxl和poi. 对于两者的区别网上有测试如 ...

  7. java后台处理解析json字符串的两种方式

    简单说一下背景 上次后端通过模拟http请求百度地图接口,得到的是一个json字符串,而我只需要其中的某个key对应的value. 当时我是通过截取字符串取的,后来觉得不太合理,今天整理出了两种处理解 ...

  8. Java代码模拟http请求的两种方式

    z这里用百度地图的逆地理编码接口为例, 第一种方式:(通过jdk中的java.net包) 引入工具类 import java.net.URL; import java.net.URLConnectio ...

  9. Spring框架访问数据库的两种方式的小案例

    1.1 以Xml的方式访问数据库的案例 要以xml的方式访问数据库需要用到JdbcTemplate ,因为 JdbcTemplate(jdbc的模板对象)在Spring 中提供了一个可以操作数据库的对 ...

随机推荐

  1. ADB Shell之手机性能测试

    Connect 夜神模拟器for Android 4.4.2 打开模拟器-在CMD输入如下连接测试设备 adb connect 127.0.0.1:62001 你也可以连接自己的手机设备 开发者选项- ...

  2. Spring的事务管理(理论篇,下篇提供代码实现)

    事务:逻辑上的一组操作,这组操作要么全部成功,要么全部失败(事务十大特性:原子性,一致性,隔离性,持久性) 原子性:事务是不可分割的工作单位,事务中的操作要么都发生了,要么都不发生.(也就是说不能单独 ...

  3. HBase MetaStore和Compaction剖析

    1.概述 客户端读写数据是先从HBase Master获取RegionServer的元数据信息,比如Region地址信息.在执行数据写操作时,HBase会先写MetaStore,为什么会写到MetaS ...

  4. 常系数齐次线性递推 & 拉格朗日插值

    常系数齐次线性递推 具体记在笔记本上了,以后可能补照片,这里稍微写一下,主要贴代码. 概述 形式: \[ h_n = a_1 h_{n-1}+a_2h_{n-2}+...+a_kh_{n-k} \] ...

  5. BZOJ 4698: Sdoi2008 Sandy的卡片 [后缀自动机]

    4698: Sdoi2008 Sandy的卡片 题意:差分后就是多个串LCS SAM+map大法好 模板打错 智力-2 #include <iostream> #include <c ...

  6. 洛谷 P3616 富金森林公园 [树状数组]

    传送门 维护一个山脉,单点修改,查询有多少山峰高出水面 我是沙茶沙茶题都不会做只想到无修改可以用扫描线 答案就是所有比水面高的-相邻都比水面高的啊 因为没有区间询问写个$BIT$都可以 有区间询问?可 ...

  7. iOS学习——UIView的研究

    在iOS开发中,我们知道有一个共同的基类——NSObject,但是对于界面视图而言,UIView是非常重要的一个类,UIView是很多视图控件的基类,因此,对于UIView的学习闲的非常有必要.在iO ...

  8. 2018/1/19 Netty学习笔记(一)

    这段时间学了好多好多东西,不过更多是细节和思想上的,比如分布式事物,二次提交,改善代码质量,还有一些看了一些源码什么的; 记录一下真正的技术学习,关于Netty的学习过程; 首先说Netty之前先说一 ...

  9. 计算机基础之Windows10操作系统安装U盘制作

    1.第一步,下载Windows10--ISO镜像(Windows7类似),下载站点: https://msdn.itellyou.cn/(百度搜索msdn即可),个人认为这是最干净的操作系统镜像站点, ...

  10. ES6中let和闭包

    在开始本文之前我们先来看一段代码 for(var i=0;i<10;i++){ arr[i]=function(){ return i; } } console.log(arr[3]());// ...