Android(9)——SQLite数据库操作,GreenDao数据库框架

Android

安卓开发者指南:https://developer.android.google.cn/guide

1 SQLite数据库

SQLite是一个轻量级、零配置、可嵌入程序驱动的二进制文件,也是开源的关系型数据库,实现自包容、零配置、支持事务的SQL数据库引擎。特点是高度便携、使用方便、结构紧凑、高效、可靠。

Sqlite的使用场景
现在的主流移动设备像Android、iPhone 等都使用SQLite作为复杂数据的存储引擎,在为移动设备开发应用程序时,也许就要使用到SQLite来存储大量的数据,所以就需要掌握移动设备上的SQLite开发技巧。对于Android平台来说,系统内置了丰富的API来供开发人员操作SQLite,可以轻松的完成对数据的存取。

DDL(数据库定义语言):create table 表名 (列名 数据类型 约束,…)
DML(数据库操作语言):
insert into 表名(列1,列2) values (值1,值2)
insert into 表名 values(值1,值2,值3)
(插入:数据类型个数顺序对应;一定要包含所有非空列;自动增长列的值设置不存在的值或null)
delete from 表名 [where 删除条件]
update 表名 set 列名1=更新值1,列名2=更新值2,列名n=更新值n [where <更新条件>]
select * from 表名

1.1 Android中操作SQL语句

  1. 布局文件
  2. 实现增删改查点击事件
    SQLiteOpenHelper抽象类
    Android平台里一个数据库辅助类,用于创建或打开数据库,并且对数据库的创建和版本进行管理。回调方法onCreate()用于数据库以及表的创建,onUpgrade()用于数据库升级。


    性别单选按钮的切换,设置默认值,private String genderStr = “男”;

    新增

    查询所有:(stuList是一个ListView控件)

    条件查询

    数据库设置ID列名为_id原因:SimpleCursorAdapter定义初期要求数据源(第三个参数)里面有_id列。
    删除

    修改(操作完记得把输入框清空):

    每次操作完应该添加一个人性化的操作提示,例如:Toast.makeText(this,“添加成功”,Toast.LENGTH_SHORT).show();
Sqlite数据库中获取数据库对象的两个方法

1)获取数据库实例时使用了 getWritableDatabase()方法。
2)在getReadableDatabase()方法中,首先判断是否已存在数据库实例并且是打开状态,如果是,则直接返回该实例,否则试图获取一个可读写模式的数据库实例,如果遇到磁盘空间已满等情况获取失败的话,再以只读模式打开数据库,获取数据库实例并返回,然后为数据库对象赋值为最新打开的数据库实例。
3) getReadableDatabase()一般都会返回和getWritableDatabase()一样的数据库实例,所以我们在DBManager构造方法中使用getWritableDatabase()获取整个应用所使用的数据库实例是可行的。
4)当调用SQLiteOpenHelper的getWritableDatabase()或者getReadableDatabase()方法获取用于操作数据库的SQLiteDatabase实例的时候,如果数据库不存在,Android系统会自动生成一个数据库,接着调用onCreate()方法。
5) onCreate()方法在初次生成数据库时才会被调用在onCreate()方法里可以生成数据库表结构及添加一些应用使用到的初始化数据。
6)onUpgrade()方法在数据库的版本发生变化时会被调用,一般在软件升级时才需改变版本号,而数据库的版本是由程序员控制的。

1.2 SQLiteDatabase操作数据库

用于管理和操作SQLite数据库,几乎所有的数据库操作,最终都将由这个类完成。

在Android平台上,SQLiteDatabase类下提供了两套方法操作数据:

  1. 方法一:需要正确的SQL语句
    rawQuery():查询
    execSQL():添加、删除、修改、创建
  2. 方法二:使用API封装方法,都不需要写sql语句,根据参数操作数据库:
    查询:db.query(table, columns, selection, selectionArgs, groupBy, having, orderBy)
    添加:db.insert(table, nullColumnHack, values)
    删除:db.delete(table, whereClause, whereArgs):返回long型数据,表示受影响行数
    修改:db.update(table, values, whereClause, whereArgs):返回long型数据,表示受影响行数

select count(*),age from info_tb group by age having age>23 order by age desc(降序)


1.3 使用面向对象思想封装操作

Student学生实体类:int id, String name, int age, String gender,无参/有参构造
Dao:data access object数据访问对象,对数据库的操作对象
StudentDao.java




最后在Activity中调用这个类的方法就可以了

1.4 sqlite expert

查看db文件的第三方工具
下载:http://sqliteexpert.com/download.html

2 GreenDao数据库框架

2.1 GreenDao简介

SqliteOpenHelper使用复杂

GreenDao是典型的ORM框架。Object-Relational_Mapping,它的作用是在关系型数据库和对象之间作一个映射,这样在具体的操作数据库的时候,就不需要再去和复杂的SQL语句打交道,只要像平时操作对象一样操作它就可以了。

GreenDao简介
◆Android平台的对象关系映射工具(ORM)
◆为关系型数据库提供面向对象的接口
◆简化数据库操作

GreenDao的优势
◆性能 (可能是Android上最快的ORM )
◆易用性 (强大的API,涵盖关系和链接)
◆轻量 (最小的内存消耗与小于100KB的库大小)

2.2 GreenDao使用

GreenDao的使用步骤
◆创建实体类
◆生成对应的DaoMaster、DaoSession、Dao
◆通过Dao对象完成增删改查

  1. 引入GreenDao库
    在github上面查看使用的方式:https://github.com/greenrobot/greenDAO
    root的build.gradle中引入插件:
buildscript {
    repositories {
        jcenter()
        mavenCentral() // add repository
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.5.3'
        classpath 'org.greenrobot:greendao-gradle-plugin:3.3.0' // add plugin
    }
}

In your app modules app/build.gradle file:

apply plugin: 'com.android.application'
apply plugin: 'org.greenrobot.greendao' // apply plugin
 
dependencies {
    implementation 'org.greenrobot:greendao:3.3.0' // add library
}
  1. GreenDao的核心概念
    ◆某实体类----->某表
    ◆某DAO------->数据访问对象(某表的操作)
    ◆DaoMaster----> 数据库连接对象
    ◆DaoSession—> 由连接生成的会话

  2. GreenDao的常用注解
    ◆@Entity – 实体注解
    ◆@NotNull – 设置表中当前列的值不可为空
    ◆@Convert – 指定自定义类型(@link PropertyConverter)
    ◆@Id – 主键Long型,可以通过@Id(autoincrement = true)设置自增长
    ◆@Index – 创建一个索引
    ◆@JoinEntity – 定义表连接关系
    ◆@Unique – 向数据库列添加了一个唯一-的约束
    ◆@OrderBy – 指定排序

1 连接数据库

1.实体类

make project后,会生成一些初始化的代码
看目录中,多生成的文件
2.Application中连接数据库
在AndroidMenifest.xml中去声明< Application android:name=".MyApplication">

public class MyApplication extends Application {
	public static DaoSession mSession;
	@Override
	public void onCreate() {
		super.onCreate();
		initDb();
	}
	// 连接数据库并创建会话
	public void initDb() {
		//1、获取需要连接的数据库
		DaoMaster.DevOpenHelper devopenHelper = new DaoMaster.DevOpenHelper(this,"imooc.db");
		SqlLiteDatabase db = devOpenHelper.getWritableDatabase();
		//2、创建数据库连接
		DaoMaster daoMaster = new DaoMaster(db);
		//3、创建数据库会话
		mSession = daoMaster.newSession() ;
	}
}

3.创建实体类
布局文件




activity_goods_detail.xml

定义数据,模拟从后台读取过来的数据:
在这里插入图片描述
4.实现GreenDao逻辑
DataUtils.java

public class DataUtils {
//获取数据
    public static String getJson(String fileName, Context context) {
        //将json数据变成字符串
        StringBuilder stringBuilder = new StringBuilder();
        try {
            //获取assets资源管理器
            AssetManager assetManager = context.getAssets();
            //通过管理器打开文件并读取
            BufferedReader bf = new BufferedReader(new InputStreamReader(
                    assetManager.open(fileName)));
            String line;
            while ((line = bf.readLine()) != null) {
                stringBuilder.append(line);
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        return stringBuilder.toString();
    }
    public static List<GoodsModel> getGoodsModels (String json){
        List<GoodsModel> result = new ArrayList<>();
        try {
            JSONArray jsonArray = new JSONArray(json);
            for (int i = 0 ; i < jsonArray.length() ; i ++) {
                JSONObject object = jsonArray.getJSONObject(i);
                GoodsModel goodsModel = new GoodsModel();
                goodsModel.setGoodsId(object.getInt("goodsId"));
                goodsModel.setIcon(object.getString("icon"));
                goodsModel.setInfo(object.getString("info"));
                goodsModel.setName(object.getString("name"));
                goodsModel.setType(object.getString("type"));
                result.add(goodsModel);
            }
        } catch (JSONException e) {
            e.printStackTrace();
        }
        return result;
    }
}

最后在MainActivity
中点击按钮调用方法insertGoods()
查看的话,可以在AS自带的Tool Windows–DeviceFileExplorer,data/data/包名/database/
查询数据:


条件查询:

删除、修改数据:

操作数据之后要手动去获取查询数据,在MainActivity中修改一下,就不需要重新手动获取了。

2 数据操作

增加
Dao.insert(T entity) 添加一个实体
Dao.insertInTx(T… entities)添加多个实体

查询
◆QueryBuilder----- Dao.queryBuilder() 查询构造器
◆Properties----- Dao.Properties 根据属性生成的相关属性类

QueryBuilder
◆query.where(WhereCondition cond, WhereCondition… condMore)
◆query.orderAsc(Propert… properties)
◆query.limit(int limit)

Properties
◆eq(Object value)
◆like(String value)
◆in(Object… inValues)

删除
◆Dao. delete(T entity)
◆Dao. deleteAll()
◆Dao. deleteByKey(K key)

修改
◆Dao. update(T entity)
◆Dao. updateInTx(T… entities)

3 数据库加密

◆引入库:compile ‘net.zetetic:android-database-sqlcipher:3.5.9@aar’
◆在连接数据库的地方:
devOpenHelper.getEncryptedWritableDb("< your-secret-password>");
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值