Java嵌入式数据库LMini-0.1.2及其通讯录使用示例发布

简介:
文章关键字:Java 嵌入式开发 DB data 通讯录 address book 文本数据库 微型 记录 数据

下载地址: [url]http://code.google.com/p/greenvm/downloads/list[/url]

LMini是Loonframework分支项目之一,它是一个仅有55KB的纯Java嵌入式文本数据库,不支持SQL语句,完全以面向对象方式进行数据操作,在Loonframework主包中主要负责实现缓存数据的硬盘持久化功能。但作为项目分支,LMini并非必须与Loonframework主包集成,也允许作为单独的微型数据库存在。

LMini的开发目的在于提供一种简单快捷的本地数据持久化方式,如游戏记录、文件缓存、简单的增、删、改、查操作都可以通过LMini得以实现,它的优势在于完全脱离java.sql包依赖,比db4o、sqllite体积更小,比Properties所提供的功能等多。

LMini通过MDB接口进行数据库操作,而根据MDB接口所获得的不同实例,操作模式又可分为如下三种,即:内存模式、单一文件模式及多文件模式。

内存模式:

实例化此模式后,将直接在内存开辟一块区域进行数据库模拟操作,当程序关闭时内存数据库也随之消失,不能持久化保存,调用方法为Engine.getMEMDB。

单一文件模式:

实例化此模式后,数据库将以文件形式存在,程序会自动产生唯一的物理文件于硬盘之上,所有操作也将基于此物理文件进行,只要此文件不被删除数据将永久存在,调用方法为Engine.getMDBOnly。

多文件模式:

实例化此模式后,数据库将以文件夹形式存在,程序会自动根据创建的表格产生多个物理文件于此文件夹中,所有操作将基于此文件夹进行
,只要此文件夹及其中文件不被破坏,数据将永久存在,调用方法为Engine.getMDBMany。

以上三种模式皆为接口实现,操作方法完全一致,仅在保存方式上有所分别。

基本操作方式:

1、数据库的创建与打开:

   当我们对MDB接口进行实例化,并调用begin方法后,LMini会自动监测指定位置是否已有文本数据库存在,有则加载其文件内容,没有将自动创建一个空数据库于指定位置。

   LMini以一个begin方法打开数据库连接,以end方法关闭连接,具体代码如下:

      
MDB mdb = Engine.getMDBOnly( "c:\\test.db");
mdb.begin();
mdb.end();


2、密码保护功能:

除内存模式之外,LMini提供了简单的密码保护功能,以防止数据库文件被他人盗用,只要在begin创建数据库时设定即可,密码错误时再次打开此文件将提示异常,具体代码如下:

       
MDB mdb = Engine.getMDBOnly( "test.db");
        mdb.openTable( "test",TypeBase.STRING);
         //设定密码
        mdb.begin( "wt98ab");
        mdb.end();


3、增、删、改、查:

    LMini以openTable方法打开或创建一个指定表格,但区别于其它数据库,Lmini每个表格仅允许保存一种数据类型,以简化LMini文件处理过程;目前其支持的类型为Long,Integer,String,Byte[],Object五种,我们可以通过Lmini提供的TypeBase类注入需要的类型。不填写情况Lmini将默认表格存储类型为Object,也就是所有经过序列化的对象都可以存储于本地硬盘之上。

    LMini针对CRUD提供了相对应的insert、select、update、delete方法以供调用,只要注入相关对象即可完成操作,无需用户关心转换细节,具体代码如下:

   
MDB mdb = Engine.getMDBOnly( "test.db");
        mdb.openTable( "test",TypeBase.STRING);
         //设定密码
        mdb.begin( "wt98ab");
         //插入数据
        mdb.insert( "久保", "砍砍砍");
        mdb.insert( "尾田""我要成为海军");
        mdb.insert( "岸本""都死光了");
         //删除数据
        mdb.delete( "岸本");
         //变更数据
        mdb.update( "尾田""我要成为海贼王");
         //查询
        System.out.println(mdb.select( "尾田"));
        mdb.end();

     
4、表格中数据的遍历:

   LMini提供了getTableKey方法以获得当前表格下所有字段名,提供了getTableList方法以获得当前表格下所有字段及数据,具体代码如下:

         
MDB mdb = Engine.getMDBOnly( "test.db");
                mdb.openTable( "test",TypeBase.STRING);
                 //设定密码
                mdb.begin( "wt98ab");
                 //插入数据
                mdb.insert( "久保", "砍砍砍");
                mdb.insert( "尾田""我要成为海军");
                mdb.insert( "岸本""都死光了");
                 //删除数据
                mdb.delete( "岸本");
                 //变更数据
                mdb.update( "尾田""我要成为海贼王");
                 //查询
                System.out.println( "尾田说:"+mdb.select( "尾田"));
             
                 for(Iterator it=mdb.getTableKey().iterator();it.hasNext();){
                        String name=(String)it.next();
                        System.out.println( "字段名:"+name);
                        System.out.println( "数据: "+(String)mdb.getTableList().get(name));
                }
             
                mdb.end();        

    
程序示例:

本例提供了一个Lmini操作通讯录的简单操作示例,利用开源metawidget项目所提供的addressbook-swing加以改造而成,仅替换其直接硬编码在Table中数据为真实操作Lmini数据库并修正部分英文窗体为中文,metawidget项目所有权利均与本人无关,本示例仅为借用其界面,特此声明。(PS:源码在jar中,另外使用metawidget的UI还挺费空间,要用5MB的支持库|||……)






LMini的操作方式非常简便,笔者昨天预告的TLOH项目的游戏存档器也将采用LMini加以实现,目前LMini还在不断完善中,希望各位看客能给予支持及指正,另外现在发的LMini比Loonframework主包中的版本差一次更新,具体差别到发布Loonframework-0.2.0时就能看到了。 

下载地址(这些小程序依例丢在code.google上):[url]http://code.google.com/p/greenvm/downloads/list[/url]



本文转自 cping 51CTO博客,原文链接:http://blog.51cto.com/cping1982/141192

相关文章
|
16天前
|
Java 关系型数据库 数据库连接
JDBC:Java与数据库的“黄金搭档”,为何它如此重要?
JDBC:Java与数据库的“黄金搭档”,为何它如此重要?
33 8
|
16天前
|
Java 数据库连接 API
JDBC:Java数据库连接的“黑科技”大揭秘
JDBC:Java数据库连接的“黑科技”大揭秘
30 7
|
1天前
|
存储 关系型数据库 MySQL
【Java面试题汇总】MySQL数据库篇(2023版)
聚簇索引和非聚簇索引、索引的底层数据结构、B树和B+树、MySQL为什么不用红黑树而用B+树、数据库引擎有哪些、InnoDB的MVCC、乐观锁和悲观锁、ACID、事务隔离级别、MySQL主从同步、MySQL调优
【Java面试题汇总】MySQL数据库篇(2023版)
|
16天前
|
SQL Java 关系型数据库
探索Java数据库连接的奥秘:JDBC技术全攻略
探索Java数据库连接的奥秘:JDBC技术全攻略
38 8
|
16天前
|
SQL Java 数据库连接
JDBC之旅:从陌生到熟悉的Java数据库连接之路
JDBC之旅:从陌生到熟悉的Java数据库连接之路
19 8
|
16天前
|
SQL Java 数据库连接
Java开发者必知:JDBC连接数据库的“三大法宝”
Java开发者必知:JDBC连接数据库的“三大法宝”
16 7
|
10天前
|
关系型数据库 Java MySQL
"解锁Java Web传奇之旅:从JDK1.8到Tomcat,再到MariaDB,一场跨越数据库的冒险安装盛宴,挑战你的技术极限!"
【9月更文挑战第6天】在Linux环境下安装JDK 1.8、Tomcat和MariaDB是搭建Java Web应用的关键步骤。本文详细介绍了使用apt-get安装OpenJDK 1.8、下载并配置Tomcat,以及安装和安全设置MariaDB(MySQL的开源分支)的方法。通过这些步骤,您可以快速构建一个稳定、高效的开发和部署环境,并验证各组件是否正确安装和运行。这为您的Java Web应用提供了一个坚实的基础。
25 0
|
安全 JavaScript 前端开发
java基础示例
这篇文章将为大家详细讲解有关java基础之方法的示例分析
|
1天前
|
存储 缓存 安全
【Java面试题汇总】多线程、JUC、锁篇(2023版)
线程和进程的区别、CAS的ABA问题、AQS、哪些地方使用了CAS、怎么保证线程安全、线程同步方式、synchronized的用法及原理、Lock、volatile、线程的六个状态、ThreadLocal、线程通信方式、创建方式、两种创建线程池的方法、线程池设置合适的线程数、线程安全的集合?ConcurrentHashMap、JUC
【Java面试题汇总】多线程、JUC、锁篇(2023版)
|
12天前
|
监控 Java 调度
【Java学习】多线程&JUC万字超详解
本文详细介绍了多线程的概念和三种实现方式,还有一些常见的成员方法,CPU的调动方式,多线程的生命周期,还有线程安全问题,锁和死锁的概念,以及等待唤醒机制,阻塞队列,多线程的六种状态,线程池等
74 6
【Java学习】多线程&JUC万字超详解