MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 它的特点是高性能、易部署、易使用,存储数据非常方便。
MongoDB服务端可运行在Linux、Windows或OS X平台,支持32位和64位应用,默认端口为27017。
一个CRUD例子,虽然简单,不过也算是覆盖了大多数核心内容了,
一边看代码一边看注释吧,挺简单的。
- import java.util.*;
- import com.mongodb.*; //com.mongodb包类似于java.sql,大多数与数据库相关的类都在这里
- public class MongoTest {
- public static void out(Object o) {
- System.err.println(o);
- }
- public static void out() {
- System.err.println();
- }
- public static void main(String[] args) throws Exception {
- //Mongo是与java.sql.Connection同等级别的概念,
- //默认是链接到127.0.0.1:27017/test,
- //见getConnectPoint()的输出结果,其中27017是端口号,test是数据库名
- Mongo mongo = new Mongo();
- out("mongo.getConnectPoint() = "+mongo.getConnectPoint());
- //查看所有的数据库名
- for(String dbName : mongo.getDatabaseNames()) {
- out("dbName = "+dbName);
- }
- //DB类用来表示一个数据库,如果数据库不存在则创建一个
- DB db = mongo.getDB( "test" );
- //查看所有的Collection名
- for(String collectionName : db.getCollectionNames()) {
- out("collectionName = "+collectionName);
- }
- out();
- //DBCollection类用来存放对象,类似数据库表的概念
- DBCollection coll = db.getCollection("testCollection");
- //插入10个User对象到coll
- //插入DBCollection中的对象必需实现DBObject接口(见User类的注释)
- for(int i=1; i<=10; i++) {
- User user = new User();
- user.setName("user "+(10+i));
- user.setAge(10+i);
- user.setDate(new Date());
- coll.insert(user);
- }
- findAll(coll); //查找出coll中的所有对象并打印输出
- //查找出第一条记录,在内部会自动转换成User类型
- coll.setObjectClass(User.class);
- User user = (User)coll.findOne();
- out("user.name="+user.getName());
- out("user.age="+user.getAge());
- out("user.getDate()="+user.getDate());
- coll.setObjectClass(BasicDBObject.class); //还原最初的对象类型