热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Android数据库框架ORMLite的学习笔记

在开发APP过程中,难免会用到数据库。而Android现主要使用SQLite数据库,这里就不对SQLite做介绍了。但SQLite的数据库操作语句难免有些繁琐,而ORMLite框架很好的

       在开发APP过程中,难免会用到数据库。而Android现主要使用SQLite数据库,这里就不对SQLite做介绍了。但SQLite的数据库操作语句难免有些繁琐,而ORMLite框架很好的简化了SQLite的操作语句,所以我给大家介绍一下ORMLite的简单使用方法。使用的IDE是AndroidStudio。

    第一步:集成ORMLite的jar,在gradle中添加

                  compile 'com.j256.ormlite:ormlite-android:4.48'
                  compile 'com.j256.ormlite:ormlite-core:4.48'

    第二步:创建自己的Bean类

@DatabaseTable(tableName = "tb_personal")          //创建的表名
public class PersonanlBean {
@DatabaseField(generatedId = true) //id为主键且自动生成
    private int id;
@DatabaseField(columnName = "personal_name") //列名为persinal_name
private String name;
@DatabaseField(columnName = "personal_desc")
private String desc;

public PersonanlBean() {

}
public PersonanlBean(String name,String desc) {
this.name = name;
this.desc = desc;
}
    //利用快捷键快速生成setter、getter方法    public int getId() {        return id;    }    public void setId(int id) {        this.id = id;    }    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public String getDesc() {        return desc;    }    public void setDesc(String desc) {        this.desc = desc;    }}
    第三步 编写DAO类,主要是获取DAO对象,这里我们需要继承OrmLiteSqliteOpenHelper,下面的方法中都要做SQLException处理

public class DaoHelp extends OrmLiteSqliteOpenHelper{
private static final String TABLE_NAME = "sqlite-school.db";

private DaoHelp(Context context) {
super(context, TABLE_NAME, null, 7); //必须实现父类的方法,其中第二个参数是创建的数据库名,第4个参数是版本号,用于升级等操作
}

@Override
public void onCreate(SQLiteDatabase database, ConnectionSource connectionSource) { try{
TableUtils.createTable(connectionSource, PersonanlBean.class); //根据PersonalBean来进行创建操作
Log.i("--ormlite:", "--onCreate:");
}catch (SQLException e){
e.printStackTrace();
}
}

@Override
public void onUpgrade(SQLiteDatabase database, ConnectionSource connectionSource, int oldVersion, int newVersion) {
try{
TableUtils.dropTable(connectionSource, PersonanlBean.class, true); //如果版本有更新则会执行onUpgrade方法,
TableUtils.createTable(connectionSource, PersonanlBean.class); //更新数据库先删除数据库再创建一个新的
Log.i("--ormlite:", "--onUpgrade:");
}catch (SQLException e){
e.printStackTrace();
}
}
// 用单例来生成DaoHelp对象
private static DaoHelp daohelp;
public static synchronized DaoHelp getDaoHelp(Context context){
if(daohelp == null){
synchronized (DaoHelp.class){
if(daohelp == null) daohelp = new DaoHelp((context));
}
}
return daohelp;
}
//利用生成的daoHelp对象来生成Dao对象,该对象是处理数据库的关键要素
private Dao, Integer> dao;
public Dao,Integer> getDao() throws SQLException{
if(dao == null){
dao = getDao(PersonanlBean.class);
}
return dao;
}
//释放资源
@Override
public void close(){
super.close();
Log.i("--ormlite:", "--close:");
dao = null;
}
}
       第四步 就是我们的数据库处理了,由于是学习,我没有做太多的UI处理,这里可能需要读者自己做下简单的UI调整,我就不做太多xml文件的描述了

直接上方法吧 

      * 获取DaoHelp对象

       DaoHelp help = DaoHelp.getDaoHelp(this);

      1:添加数据

    //添加数据
for(int i = 0; i <5; i++) {
String str1 = "name" + i;
String str2 = "desc" + i;
PersonanlBean persOnal= new PersonanlBean(str1, str2);
help.getDao().createIfNotExists(personal); //这里create的相关方法有很多就不一一描述了
}
      2:删除数据

    // 创建Builder类进行复杂的where删除
DeleteBuilder, Integer> deleteBuilder = help.getDao().deleteBuilder();
deleteBuilder.where().le("id",4); //id小于等于4的条件删除
deleteBuilder.delete();

//多id删除
ArrayList ids = new ArrayList() {};
ids.add(7);
ids.add(8);
help.getDao().deleteIds(ids); //id在ids集合中就删除

// 直接删除
help.getDao().delete(help.getDao().queryForId(9)); //指定对象删除
//指定id删除
help.getDao().deleteById(10); //指定id为的删除
       3:修改数据

    UpdateBuilder updateBuilder = help.getDao().updateBuilder();     //获取Builder对象
updateBuilder.where().eq("id", 15); //当id为15时准备修改
updateBuilder.updateColumnValue("personal_name", "sasasasasas"); //把id为15的数据进行修改
updateBuilder.update(); //执行修改操作
        4:查找数据

    // id查找,查找id为11的数据
PersonanlBean pForId = help.getDao().queryForId(11);
if(pForId != null) {
Log.i("--ormlite", "--pForIdId:" + pForId.getId() + "--pForIdName:" + pForId.getName());
}
// 字段查找,查找personal_name列名中有“name1”的所有数据,返回时集合
List pForEq = help.getDao().queryForEq("personal_name", "name1");
for (PersonanlBean str : pForEq) {
Log.i("--ormlite", "--pForEqId:" + str.getId() + "--pForEqName:" + str.getName());
}
// where查找,id小于5
List pWheres = help.getDao().queryBuilder().where().le("id", 10).query();
for (PersonanlBean str : pWheres) {
Log.i("--ormlite", "--pWheres:" + str.getId() + "--pWheres:" + str.getName());
}
    // 整体查找,遍历
QueryBuilder, Integer> queryBuilder = help.getDao().queryBuilder();
List persOnals= queryBuilder.query();
for (PersonanlBean str : personals) {
Log.i("--ormlite", "--personals" + str.getId() + ":" + str.getName());
}


总结:由于自己水平有限,写的技术含金量很低,分享的水平有限,希望各位不吝赐教,有疑问或什么的欢迎私聊,总之希望您对我的博客进行一下指点与批评。源码已上传


















推荐阅读
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 开发笔记:spring boot项目打成war包部署到服务器的步骤与注意事项
    本文介绍了将spring boot项目打成war包并部署到服务器的步骤与注意事项。通过本文的学习,读者可以了解到如何将spring boot项目打包成war包,并成功地部署到服务器上。 ... [详细]
author-avatar
Arthur小熊
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有