一起来写个SQLite ORM数据库框架(上)

2024-06-10 08:32

本文主要是介绍一起来写个SQLite ORM数据库框架(上),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

谈起Android的数据库框架、相信大家一定不会陌生 目前开源的有:

  1. GreenDao:基于编译时注解 性能较好 但是配置较麻烦
  2. Ormlite:基于运行时注解 性能一般 配置简单些
  3. Rleam:貌似不是基于表结构的 性能很好 使用简单 支持json格式 但是不支持sql语句

如果要选一个开源的话 我比较倾向和建议的是GreenDao3.0,但实际上这些我都没用过,只是看过github上面的介绍 前面两个我觉得麻烦 realm不支持sql 感觉不好用
对于第三方库来说 我一贯的思想是能不用就不用,能用轻量级的就不用重量级的,所以我一直没用过View的注解框架 而是在基类里面写这个方法

protected <E extends View> E $(int resId) {return (E) this.findViewById(resId);
}

看过ButterKnife的源码的同学应该知道 它里面也有类似的方法。

SQLiteOpenHelper

这里不得不提一下 Android自带的SQLiteDatabase的帮助类SQLiteOpenHelper,因为我之前和大多数刚学Android数据库的同学一样,用的就是这个,我们来看一下他的实现

public class DBHelper extends SQLiteOpenHelper {public DBHelper(Context context,String name,CursorFactory factory,int version) {super(context, name, factory, version);}@Overridepublic void onCreate(SQLiteDatabase db) {}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}
}

构造函数里面可以配置数据库名称和数据库版本,onCreate方法执行创建表的操作,onUpgrade里面做更新操作,那数据库是什么时候创建的呢?我们知道操作数据库的时候一般会执行getWritableDatabase()获取返回的SQLiteDatabase,我们来看下它的源码

 public SQLiteDatabase getWritableDatabase() {synchronized (this) {return getDatabaseLocked(true);}}//跟进getDatabaseLocked方法private SQLiteDatabase getDatabaseLocked(boolean writable) {......//省略其他判断的代码 if (DEBUG_STRICT_READONLY && !writable) {final String path = mContext.getDatabasePath(mName).getPath();db = SQLiteDatabase.openDatabase(path, mFactory,SQLiteDatabase.OPEN_READONLY, mErrorHandler);} else {db = mContext.openOrCreateDatabase(mName, mEnableWriteAheadLogging ?Context.MODE_ENABLE_WRITE_AHEAD_LOGGING : 0,mFactory, mErrorHandler);}......}

它源码里面主要是一个线程安全锁和读写以及是否打开创建的判断,最终会执行mContext.openOrCreateDatabase 其实还是调用的SQLiteDatabase.openDatabase(..)创建数据库,SQLiteDatabase这个类里面就是我们常用的开关数据库、事务、增删改查等操作,具体的数据库操作函数是通过JNI调用C代码执行的 而且是本地数据库 所以Android原生的SQLiteDatabase性能还是很好的。以上只是简单分析 想深入了解的朋友可以看这篇博客SQLiteOpenHelper/SQLiteDatabase/Cursor源码解析

ok,下面来说说SQLiteOpenHelper几点不方便的地方

  • 创建的数据库默认是在data/data/packgname/database目录,相对较安全,但是查看需要root权限,我的山寨手机一直root不了 之前看数据库都用的模拟器 很傻啊
  • 因为他是基于版本控制的,所以每次更新需要配置version还要在onUpgrade里面写需要更新或者添加的表,这意味着需要重新打包发布,如果数据是动态获取的,表结构是变化的,这样肯定不行
  • 最麻烦的就是自己要写大量的sql语句,我最近的项目里面一个实体类有一百多个字段,让我写sql会疯的

自己写一个吧

参考了开源的TigerDB ,写了一个基于SQLite简单的ORM框架—easyDB

https://github.com/1139618418/easyDB

下一章节介绍具体的代码实现

这篇关于一起来写个SQLite ORM数据库框架(上)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1047663

相关文章

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

在Java中基于Geotools对PostGIS数据库的空间查询实践教程

《在Java中基于Geotools对PostGIS数据库的空间查询实践教程》本文将深入探讨这一实践,从连接配置到复杂空间查询操作,包括点查询、区域范围查询以及空间关系判断等,全方位展示如何在Java环... 目录前言一、相关技术背景介绍1、评价对象AOI2、数据处理流程二、对AOI空间范围查询实践1、空间查

Python+PyQt5实现MySQL数据库备份神器

《Python+PyQt5实现MySQL数据库备份神器》在数据库管理工作中,定期备份是确保数据安全的重要措施,本文将介绍如何使用Python+PyQt5开发一个高颜值,多功能的MySQL数据库备份工具... 目录概述功能特性核心功能矩阵特色功能界面展示主界面设计动态效果演示使用教程环境准备操作流程代码深度解

C++ HTTP框架推荐(特点及优势)

《C++HTTP框架推荐(特点及优势)》:本文主要介绍C++HTTP框架推荐的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Crow2. Drogon3. Pistache4. cpp-httplib5. Beast (Boos

MySQL数据库实现批量表分区完整示例

《MySQL数据库实现批量表分区完整示例》通俗地讲表分区是将一大表,根据条件分割成若干个小表,:本文主要介绍MySQL数据库实现批量表分区的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录一、表分区条件二、常规表和分区表的区别三、表分区的创建四、将既有表转换分区表脚本五、批量转换表为分区

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

MySQL Workbench工具导出导入数据库方式

《MySQLWorkbench工具导出导入数据库方式》:本文主要介绍MySQLWorkbench工具导出导入数据库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录mysql Workbench工具导出导入数据库第一步 www.chinasem.cn数据库导出第二步

Mysql数据库中数据的操作CRUD详解

《Mysql数据库中数据的操作CRUD详解》:本文主要介绍Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括... 目录一、插入数据(insert)1.插入数据的语法2.注意事项二、修改数据(update)1.语法2.有

查看MySQL数据库版本的四种方法

《查看MySQL数据库版本的四种方法》查看MySQL数据库的版本信息可以通过多种方法实现,包括使用命令行工具、SQL查询语句和图形化管理工具等,以下是详细的步骤和示例代码,需要的朋友可以参考下... 目录方法一:使用命令行工具1. 使用 mysql 命令示例:方法二:使用 mysqladmin 命令示例:方