Berkeley DB的JAVA连接

来源:互联网 发布:淘宝电商培训课程表 编辑:程序博客网 时间:2024/05/21 10:52
        Berkeley DB是一个嵌入式的数据库,它适合于管理海量的、简单的数据。关键字/数据(key/value)是Berkeley DB用来进行数据管理的基础。每个key/value构成了一条记录,而整个数据库实际上就是由许多这样的结构单元构成的,使用其提供的API访问数据库时,只需要提供关键字就能访问到相应的数据。当然也可以在提供Key和部分Data来查询符合条件的相近数据。

  Berkeley DB底层实现采用B树,可以看成能够存储大量数据的HashMap。Berkeley DB是通过环境对象EnvironmentConfig来对数据库进行管理的,每个EnvironmentConfig对象可以管理多个数据库,建立一个新的EnvironmentConfig的代码如下:

1 EnvironmentConfig envConfig = new EnviromentConfig();2 envConfig.setTransactional(false);3 envConfig.setAllowCreate(true);4 exampleEnv = new Environment(envDir, envConfig);

        其中,envDir是用户指定的一个目录,只要是同一个EnvironmentConfig指定的数据库文件和日志文件,都会放在这个目录下。EnvironmentConfig也是一种资源,当使用完毕后,应该释放掉。

1 exampleEnv.sync();2 exampleEnv.close();3 exampleEny = null;

        创建好环境之后,就可以用它创建数据库了。用Berkeley DB创建数据库时,需要指定数据库的属性,就好比在Orcal中创建数据库里要指定java_pool、buffer_size等属性一样。Berkeley DB使用DatabaseConfig来管理一个具体的Database。

String databaseName = "ToDoTastList.db";DatabaseConfig dbConfig = new DataBaseConfig();dbConfig.setAllowCreate(true);dbConfig.setTransactional(false);dbConfig.setSortedDuplicates(false);Database myClassDb = exampleEnv.openDatabase(null, "classDb", dbconfig);catalog = new StoreClassCatalog(myClassDb);TupleBinding keyBinding = TupleBinding.getPrimitiveBinding(String.class);serialBinding valueBinding = new SerialBinding(catalog, NewsSource.class);store = exampleEnv.openDatabase(null, databaseName, dbConfig);

当数据库建立起来之后,就要确定往数据库里存储的数据类型,Berkeley DB数据类型是采用EntryBinding来确定的。

1 EntryBinding keyBinding = new SerialBinding(javaCatalog, String.class);

        其中,SerialBinding表示这个对象能够序列化到磁盘上,因此,构造函数的第二个参数一定要是实现了序列化接口的对象。

  最后,创建一个以Berkeley DB为底层数据结构的Map:

1 this.map = new StoredSortedMap(store, keyBinding, valueBinding, true);


0 0
原创粉丝点击