首页 热点资讯 义务教育 高等教育 出国留学 考研考公

android 数据库框架哪个好

发布网友 发布时间:2022-04-26 16:03

我来回答

3个回答

懂视网 时间:2022-04-30 07:15

public class Person { @DatabaseField(generatedId = true)//设置生成id private int Id; @DatabaseField(columnName = "name")//设置字段名称 private String name; public Person(){} public Person(String s) { this.name = s; } public String getName() { return name; } public void setName(String name) { this.name = name; } }

自定义OpenHelper类 OpenHelper.java

public class OpenHelper extends OrmLiteSqliteOpenHelper {
 private Dao<Person, Integer> mPersonDao;

 public OpenHelper(Context context) {
 super(context, "test", null, 1);//初始化,数据库名称为test
 }

 @Override
 public void onCreate(SQLiteDatabase sqLiteDatabase, com.j256.ormlite.support.ConnectionSource connectionSource) {
 try {
  TableUtils.createTable(connectionSource, Person.class);//根据配置好的实体类建表
 } catch (SQLException e) {
  e.printStackTrace();
 }
 }

 @Override
 public void onUpgrade(SQLiteDatabase sqLiteDatabase, com.j256.ormlite.support.ConnectionSource connectionSource, int i, int i1) {

 }

 public Dao<Person, Integer> getPersonDao() throws java.sql.SQLException {//该方法用来返回DAO类
 if (mPersonDao == null) {
  mPersonDao = getDao(Person.class);
 }
 return mPersonDao;
 }
}

测试类Test.java

public class Test extends AndroidTestCase {
 public void testAdd()
 {
 Person p1 = new Person("u3");
 OpenHelper helper = new OpenHelper(getContext());//新建一个OpenHelper对象
 try {
  helper.getPersonDao().create(p1);//添加一条记录
  p1 = new Person("u31");
  helper.getPersonDao().create(p1);//添加一条记录
  p1 = new Person("u32");
  testList();//查询并打出所有记录
 } catch (SQLException e) {
  e.printStackTrace();
 }
 }
 public void testList()
 {
 OpenHelper helper = new OpenHelper(getContext());//建立OpenHelper对象
 try {
  List<Person> users = helper.getPersonDao().queryForAll();//通过DAO来查询所有的记录
  Log.v("sk", users.toString());//打印在LOGO之中
 } catch (SQLException e) {
  e.printStackTrace();
 }
 }
}

【一个更复杂的例子】

热心网友 时间:2022-04-30 04:23

请看sqllite增删改查的小例子,例子来自于android学习手册,里面有源码。android学习手册包含9个章节,108个例子,源码文档随便看,例子都是可交互,可运行,源码采用android studio目录结构,高亮显示代码,文档都采用文档结构图显示,可以快速定位。360手机助手中下载,图标上有贝壳

先介绍一下ORM的概念,以前也一直听说,不过没详细了解啥意思。其全称叫做对象关系映射(Object Relation Mapping),是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换。从效果上说,它其实是创建了一个可在编程语言里使用的“虚拟对象数据库”。
面向对象是从软件工程基本原则(如耦合、聚合、封装)的基础上发展起来的,而关系数据库则是从数学理论发展而来的.  两者之间是不匹配的.而ORM作为项目中间件形式实现数据在不同场景下数据关系映射. 对象关系映射是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术.ORM就是这样而来的。


下面先列出几个ORM框架:ORMLite、green、ormndroid、androrm、ActiveAndroid

其中以前最早接触过ormlite,GreenDao了解过,其他的几个真没怎么见过。所以这里主要介绍ormlite和GreenDao。

最开始现在stackoverflow输入sqlite orm关键字,搜索出了一些相关的文章:http://stackoverflow.com/search?q=sqlite+orm ,你会发现很有趣的是,ormlite的作者Gray和greenDao的开发团队green robot同时出现在一些帖子中,向提问者推荐他们的框架。当然也会有一些热心的朋友推荐ormdroid。其实不论在stackoverflow上还是官网上,greenDao的团队的比较都是针对ORMLite的,可见,其主要的竞争对手,或许称互相促进者更合适,毕竟他们没有什么商业利益,完全开源。所以开源的ORM框架中,ormLite和greenDao是最火的。其它几种就不做比较,有兴趣的朋友可以到官网看下。下面对ORMLite和GreenDao做个简单的比较:


ormlite
基于注解和反射的的方式,导致ormlite性能有着一定的损失(注解其实也是利用了反射的原理)

优点:
文档较全面,社区活跃,有好的维护,使用简单,易上手。

缺点:
基于反射,效率较低

GreenDao

官网中明确指明了其首要设计目标:
Maximum performance (probably the fastest ORM for Android):系能最大化
Easy to use APIs:便于使用
Highly optimized for Android:对于Android高度优化
Minimal memory consumption:最小化内存开销
Small library size, focus on the essentials:较小的文件体积,只集中在必要的部分上。

优点:
效率很高,插入和更新的速度是sqlite的2倍,加载实体的速度是ormlite的4.5倍。官网测试结果:http:/

/green-orm.com/features/
文件较小(<100K),占用更少的内存 ,但是需要create Dao,
操作实体灵活:支持get,update,delete等操作


缺点:

学习成本较高。其中使用了一个java工程根据一些属性和规则去generate一些基础代码,类似于javaBean但会有一些规则,另外还有QueryBuilder、Dao等API,所以首先要明白整个过程,才能方便使用。没有ORMLite那样封装的完整,不过greenDao的官网上也提到了这一点,正是基于generator而不是反射,才使得其效率高的多。


另外GreenDao支持Protocol buffers协议数据的直接存储 ,如果通过protobuf协议和服务器交互,不需要任何的映射。

Protocol Buffers协议:以一种高效可扩展的对结构化数据进行编码的方式。google内部的RPC协议和文件格式大部分都是使用它。
RPC:远程过程调用(Remote Procere Call,RPC)是一个计算机通信协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。


可能因为GreenDao的效率高,而且需要学习成本高点,所以个人还是有兴趣学一学的。接下来会发布一些GreenDao更详细的文章,有对官方文档的翻译还有代码的简单讲解。

或许以上内容很简单,只是简单的介绍了下,对其它几个框架并没有做更多的介绍,有了解的朋友可以提出来,可以提出来,大家一起探讨下。

热心网友 时间:2022-04-30 05:41

xutils 。
android中的orm框架,一行代码就可以进行增删改查;
支持事务,默认关闭;
可通过注解自定义表名,列名,外键,唯一性约束,NOT NULL约束,CHECK约束等(需要混淆的时候请注解表名和列名);
支持绑定外键,保存实体时外键关联实体自动保存或更新;
自动加载外键关联实体,支持延时加载;

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com