也来玩玩MongoDB

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
简介:

最近NoSQL(或者NoRelation)很火,咱不想Out了,所以也来凑凑热闹。

概念、优点之类的东西就不在这里重复啰嗦了,
直接动手玩一下。

MongoDB(包括Java驱动)的官方文档写得不够认真,
连个最普通的CRUD例子都没有,
看过网站上那篇“Java - Saving Objects Using DBObject”文章的人肯定被气晕了。。。

安装:
1)下载MongoDB数据库(这里使用Windows 32 bit版)

http://downloads.mongodb.org/win32/mongodb-win32-i386-1.2.4.zip

然后解压到一个目录(这里是D:MongoDB),
并且在D:MongoDB目录中建个”datadb”目录用来存放数据文件。
(注意:很多文档中说”C:datadb”目录是缺省目录,实际上是不起作用的)

2)下载MongoDB数据库的Java驱动程序

http://github.com/downloads/mongodb/mongo-java-driver/mongo-1.3.jar
然后把mongo-1.3.jar放到D:MongoDB目录

完成上面两步就算完成安装任务了,够简单吧。

启动MongoDB数据库服务器:

D:>cd D:MongoDB
D:MongoDB>binmongod –dbpath datadb
能看到下面这张图就算是成功了:

下面是一个CRUD例子,虽然简单,不过也算是覆盖了大多数核心内容了,
一边看代码一边看注释吧,挺简单的。

Java代码

  1. import java.util.*;
  2. import com.mongodb.*; //com.mongodb包类似于java.sql,大多数与数据库相关的类都在这里
    3.4. public class MongoTest {
  3. public static void out(Object o) {
  4. System.err.println(o);
  5. }
  6. public static void out() {
  7. System.err.println();
  8. }
    11.12. public static void main(String[] args) throws Exception {
  9. //Mongo是与java.sql.Connection同等级别的概念,
  10. //默认是链接到127.0.0.1:27017/test,
  11. //见getConnectPoint()的输出结果,其中27017是端口号,test是数据库名
  12. Mongo mongo = new Mongo();
  13. out(“mongo.getConnectPoint() = “+mongo.getConnectPoint());
    18.19. //查看所有的数据库名
  14. for(String dbName : mongo.getDatabaseNames()) {
  15. out(“dbName = “+dbName);
  16. }
    23.24. //DB类用来表示一个数据库,如果数据库不存在则创建一个
  17. DB db = mongo.getDB( “test” );
    26.27. //查看所有的Collection名
  18. for(String collectionName : db.getCollectionNames()) {
  19. out(“collectionName = “+collectionName);
  20. }
    31.32. out();
    33.34. //DBCollection类用来存放对象,类似数据库表的概念
  21. DBCollection coll = db.getCollection(“testCollection”);
    36.37. //插入10个User对象到coll
  22. //插入DBCollection中的对象必需实现DBObject接口(见User类的注释)
  23. for(int i=1; i<=10; i++) {
  24. User user = new User();
  25. user.setName(“user “+(10+i));
  26. user.setAge(10+i);
  27. user.setDate(new Date());
    44.45. coll.insert(user);
  28. }
    47.48. findAll(coll); //查找出coll中的所有对象并打印输出
    49.50. //查找出第一条记录,在内部会自动转换成User类型
  29. coll.setObjectClass(User.class);
  30. User user = (User)coll.findOne();
  31. out(“user.name=”+user.getName());
  32. out(“user.age=”+user.getAge());
  33. out(“user.getDate()=”+user.getDate());
  34. coll.setObjectClass(BasicDBObject.class); //还原最初的对象类型
    57.58. out();
    59.60. user.setAge(100);
  35. coll.save(user); //保存更新
  36. findAll(coll); //确认第一条记录的”Age”是否变成100了?
    63.64. coll.remove(user); //删除第一条记录
    65.66. findAll(coll);
    67.68. //查找年纪大于等于15小于等于18的记录(15<=age<=18)
  37. //(查询条件的组合方式很啰嗦,这方面就没sql方便)
  38. BasicDBObject query = new BasicDBObject();
  39. //注意这里的”Age”第一个字母要大写,如果把User类替换成UserNoReflection类就用小写,
  40. //这是因为ReflectionDBObject类的内部实现在截取setter和getter方法的”set”和”get”前缀后
  41. //没有进行大小写转换,比如”setAge”得到的key值就是”Age”
  42. query.put(“Age”, new BasicDBObject(“$gte”, 15).append(“$lte”, 18));
    75.76.77. DBCursor cur = coll.find(query);
  43. while(cur.hasNext()) {
  44. out(cur.next());
  45. }
    81.82. out();
    83.84. //跳过前面3条记录,然后显示总共5条记录
  46. cur = coll.find().skip(3).limit(5);
  47. while(cur.hasNext()) {
  48. out(cur.next());
  49. }
    89.90. coll.drop(); //删除coll这个DBCollection
  50. }
    92.93. public static void findAll(DBCollection coll) {
  51. DBCursor cur = coll.find();
  52. while(cur.hasNext()) {
  53. out(cur.next());
  54. }
  55. out();
  56. }
    100.101. //插入DBCollection中的java对象必需实现DBObject接口,
  57. //ReflectionDBObject实现了DBObject接口,在内部是采用反射来完成的
  58. public static class User extends ReflectionDBObject {
  59. private String name;
  60. private int age;
  61. private Date date;
    107.108. public void setName(String name) {
  62. this.name = name;
  63. }
    111.112. public String getName() {
  64. return name;
  65. }
    115.116. public void setAge(int age) {
  66. this.age = age;
  67. }
    119.120. public int getAge() {
  68. return age;
  69. }
    123.124. public void setDate(Date date) {
  70. this.date = date;
  71. }
    127.128. public Date getDate() {
  72. return date;
  73. }
  74. }
    132.133. //如果不想用反射的方式,又不想手工实现DBObject接口的方法,
  75. //可以直接继承BasicDBObject,但是需要做额外的工作,
  76. //就像下面这样:
  77. public static class UserNoReflection extends BasicDBObject {
  78. private String name;
  79. private int age;
  80. private Date date;
    140.141. public void setName(String name) {
  81. this.name = name;
    143.144. super.put(“name”, name);
  82. }
    146.147. public String getName() {
  83. return name;
  84. }
    150.151. public void setAge(int age) {
  85. this.age = age;
    153.154. super.put(“age”, age);
  86. }
    156.157. public int getAge() {
  87. return age;
  88. }
    160.161. public void setDate(Date date) {
  89. this.date = date;
    163.164. super.put(“date”, date);
  90. }
    166.167. public Date getDate() {
  91. return date;
  92. }
    170.171. public Object put(String key, Object v) {
  93. if(key.equals(“name”)) name = (String)v;
  94. else if(key.equals(“age”)) age = (Integer)v;
  95. else if(key.equals(“date”)) date = (Date)v;
    175.176. return super.put(key, v);
  96. }
  97. }
  98. }
    把MongoTest.java文件放到D:MongoDB目录

编译:
javac -cp D:MongoDBmongo-1.3.jar D:MongoDBMongoTest.java

运行:
java -cp D:MongoDBmongo-1.3.jar;D:MongoDB MongoTest

Douyu也支持MongoDB了,比上面的代码还简洁

Java代码

  1. //对应上面的User类(或UserNoReflection类),
  2. //在Douyu中如下所示,不需要任何setter和getter代码
    3.4. import douyu.mvc.Model;
    5.6. @Model
  3. public class User {
  4. private String name;
  5. private int age;
  6. private Date date;
  7. }
    然后在conf/server.java中配置一个MongoDB的数据源(跟普通的关系型数据库类似)

最后是Controller

Java代码

  1. import java.util.Date;
  2. import douyu.mvc.Controller;
  3. import douyu.mvc.ModelManager;
    4.5. @Controller
  4. public class MongoTest {
  5. public void index(ModelManager modelManager) {
  6. User user = new User();
  7. //下面三个setter方法虽然没有在User类中声明,
  8. //但是编译器在编译User类时发现User类带有@Model,就会自动生成setter、getter方法
  9. user.setName(“user 10”);
  10. user.setAge(10);
  11. user.setDate(new Date());
    14.15. modelManager.insert(user);
    16.17. user.setAge(20);
  12. modelManager.save(user);
    19.20. modelManager.delete(user);
  13. //….
  14. }
  15. }
本文来源于"阿里中间件团队播客",原文发表时间" 2011-07-06 "
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
11月前
|
存储 NoSQL MongoDB
MongoDB3.4下载教程
MongoDB3.4下载教程
302 0
|
SQL 存储 JSON
MongoDB随手笔记(一)
MongoDB随手笔记(一)
MongoDB随手笔记(一)
|
NoSQL JavaScript MongoDB
MongoDB随手笔记(二)
MongoDB随手笔记(二)
MongoDB随手笔记(二)
|
NoSQL 关系型数据库 MySQL
Laravel框架使用MongoDB遇到的问题解决
Laravel框架使用MongoDB遇到的问题解决
95 0
|
存储 NoSQL JavaScript
mongoDB简单上手
mongoDB简单上手
223 0
mongoDB简单上手
|
存储 NoSQL JavaScript
MongoDB必备知识点全面总结(二)
MongoDB必备知识点全面总结
297 0
MongoDB必备知识点全面总结(二)
|
存储 SQL NoSQL
MongoDB必备知识点全面总结(四)
MongoDB必备知识点全面总结
190 0
MongoDB必备知识点全面总结(四)
|
存储 JSON NoSQL
MongoDB必备知识点全面总结(一)
MongoDB必备知识点全面总结
540 0
MongoDB必备知识点全面总结(一)
|
存储 JSON NoSQL
MongoDB必备知识点全面总结(三)
MongoDB必备知识点全面总结
250 0
MongoDB必备知识点全面总结(三)
|
NoSQL Java 数据库连接
上手mongodb (二)
上手mongodb (二)
186 0