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="