MongoDB入门列子及原理介绍

openkk 13年前
     <p>本文着重介绍<a href="http://www.open-open.com/lib/view/open1322699343952.html" target="_blank">mongonDB</a>的原理及安装,最后送大家一个简单的列子,有可以运行的列子和原理,相信大家很容易学会mongonDB ^_^</p>    <p>MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。意在为WEB应用提供可扩展的高性能数据存储解决方案。</p>    <p>它有一下几个特点:</p>    <p> 1.模式自由。 ( 像json数据一样可以自由的宽展) </p>    <p> 2.支持动态查询。 </p>    <p> 3.支持完全索引,包含内部对象。 </p>    <p> 4.支持查询。 </p>    <p> 5.支持复制和故障恢复。 </p>    <p> 6.使用高效的二进制数据存储,包括大型对象(如视频等)。 </p>    <p> 7.自动处理碎片,以支持云计算层次的扩展性。 </p>    <p> 8.支持RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。 </p>    <p> 9.文件存储格式为BSON(一种JSON的扩展)。 </p>    <p> 10.可通过网络访问。(和大多数据数据库一样)</p>    <p>下面是个简单的增加和查找的列子,还是那句话不为别的只为读者一最快的速度了解mongonDB</p>    <pre class="brush:java; toolbar: true; auto-links: false;">package com;  import java.net.UnknownHostException;  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.MongoException;  /** * @className:MogonDBDemo.java   * @classDescription:   * @author:jiangmianyue  * @createTime:2011-12-3  */ public class MogonDBDemo {   /**     * @MethodDescription: one simple example for mogondb   * @author:jiangmianyue   * @createTime:2011-12-3   */   public static Mongo mongo=null;    // Mongo对象   public static DB database=null;      // MongonDB的数据库对象   public static DBCollection  collection = null;    // 类似于关系数据库的表  // 静态语句块,当与类同事加载,可以一个防止频繁初始化     static{      try {      /**       *  初始化mogondb对象如果是本机Mongo()是个无参数的构造函数,如果是其他网络上的Mongo写成       *  Mongo("http://233.23.11.8:端口号/数据库")的形式      */    mongo = new Mongo();   } catch (UnknownHostException e) {    e.printStackTrace();   } catch (MongoException e) {    e.printStackTrace();   }   // 获取一个叫xuehanDB的数据库,若没有此数据库就会新建一个   database = mongo.getDB("xuehanDB");   // 获取一个teacher集合没有新建一个   collection = database.getCollection("people");     }  public static void main(String[] args) {   Teacher t1 = new Teacher();   t1.setId(1);   t1.setName("teacher1");   insertOne(t1);   query();  }  // 增加一个对象  public static void insertOne(Teacher teacher){   BasicDBObject baseObject = new BasicDBObject();   baseObject.put("id", teacher.getId());   baseObject.put("name", teacher.getName());   collection.insert(baseObject);  }  // 为对应Id的老师增加学生,例如给Id为1的老师增加学生  // 查询出所有的teacher并打印出来  public static void query(){   DBCursor cur = collection.find();   while (cur.hasNext()) {    System.out.println(cur.next());   }  }  }     // 新建一个teacher对象     class Teacher{      private int id;      private String name;   public int getId() {    return id;   }   public void setId(int id) {    this.id = id;   }   public String getName() {    return name;   }   public void setName(String name) {    this.name = name;   }           }  </pre>    <p></p>    <p>下载官方的MongoDB数据库解压到F:\job\db "cmd"进入dos界面,进入到mongonDB的bin目F:\job\db\mongodb-win32-i386-2.0.2-rc1\bin>敲入命令mongod.exe --dbpath F:\job\db\data(<span style="color:#ff0000;">必须建立F:\job\db\data文件夹,文件夹名字可以随意不过路径不能有中文</span>)敲回车mongod启动成功</p>    <p>运行java文件可以看到一下结果:</p>    <p>{ "_id" : { "$oid" : "4ed9cc01ffbf19d82ed3102b"} , "id" : 1 , "name" : "student1"}<br /> { "_id" : { "$oid" : "4ed9cc01ffbf19d82ed3102c"} , "id" : 1 , "name" : "student1"}<br /> { "_id" : { "$oid" : "4ed9cc19ffbf45716606bfb8"} , "id" : 1 , "name" : "teacher1"}<br /> { "_id" : { "$oid" : "4ed9cc92ffbf98ec2a4b8e36"} , "id" : 1 , "name" : "teacher1"}</p>    <p>每运行一次记录增加一条,呵呵,恭喜你你的mongodb第一个小程序运行成功</p>    <p></p> 转自:    <a href="/misc/goto?guid=4959498286999826828" target="_blank">http://xuehanxin.iteye.com/blog/1290563</a>