Android平台SQLite快速入门“.NET研究”实践

简介:   SQLite是Android平台软件开发中会经常用到的数据库产品,作为一款轻型数据库,SQLite的设计目标就是是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够。

  SQLite是Android平台软件开发中会经常用到的数据库产品,作为一款轻型数据库,SQLite的设计目标就是是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够。下面我们一起来看看针对Android平台的SQlite 3的使用。

  以下概念都是在Android平台的SQlite限制下的理解:

  数据库基础概念

  ◆SQlite 通过文件来保存数据库,一个文件就是一个数据库。

  ◆数据库里又包含数个表格;

  ◆每个表格里面包含了多个记录;
  ◆每个记录由多个字段组成;

  ◆每个字段都有其对应的值;

  ◆每个值都可以指定类型。

  数据库名称即文件名;表格有自己的名称;记录没有名称;每个字段都有名称。在SQlite中,记录没有顺序的概念,不存在第一、第二此类的概念;只能通过查询来获取满足条件的记录。我们通过执行SQL指令来操作数据库。

  Android平台下数据库相关类

  ◆SQLiteOpenHelper 抽象类:通过从此类继承实现用户类,来提供数据库打开、关闭等操作函数。

  ◆SQLiteDatabase 数据库访问类:执行对数据库的插入记录、查询记录等操作。

  ◆SQLiteCursor 查询结构操作类:用来访问查询结果中的记录。

  创建数据库

  假设使用一个数据库存储一个表格,表格中保存了多条记录,每个记录包含3个字段,分别是: ID、name、age。 从SQLiteOpenHelper继承实现一个类,所有对数据库的操作都封装在此类中。

构造函数:

 
 
1 . public DbHelper(Context context, String name,
CursorFactory factory,
int version) {
2 . super (context, name, factory, version);
3 . }

  此函数中的参数name就是数据库名称,也就是数据库文件名; version则从1开始,当将来数据库的表格以及字段发生变化时,用户可以提高此version,从而触发onUpgrade()达到旧数据升级的效果。

  在onCreate函数中创建表格:

 
 
1 . public void onCreate(SQLiteDatabase db) {
2 . StringBuilder sql = new StringBuilder();
3 . sql.append( " CREATE TABLE " );
4 . sql.append(TBL_NAME);
5 . sql.append( " ( " );
6 . sql.append(FIELD_ID + " TEXT PRIMARY KEY NOT NULL, " );
7 . sql.append(FIELD_NAME + " TEXT, " );
8 . sql.append(FIELD_AGE + " INTEGER " );
9 . sql.append( " ); " );
10 . db.execSQL(sql.toString());
11 . }

  onCreate函数只会在数据库第一次创建时调用,所以此处适合做一些数据库初始化操作。

  上面的函数最终实际上效果是执行了SQL语句:

CREATE TABLE mytable (id TEXT PRIMARY KEY NOT NULL, name TEXT, age INTEGER);

  向表格中添加数据

  有两种方式可以向表格中添加数据,一种是通过SQLiteDatabase提供的execSQL函数直接执行SQL指令; 一种是通过SQLiteDatabase提供的insert函数,此函数把SQL语句进行了封装方便用户使用。
  ◆通过execSQL("INSERT INTO mytable VALUES('idStr', 'nameStr', 20);");可以插入一条记录,
当插入记录出错时会抛出异常需要处理。

  ◆通过insert函数:insert函数需要一个ContentValues类型的值,此类型类似于hashmap,一个key,一个值配成一对。key就是字段名。

 
 
ContentValues v = new ContentValues();
v.put(
" id " , " 101 " );
v.put(
" name " , " user 101 " );
v.put(
" age " , 44 );
mDb.insert(
" mytable " , " null " , v);

  如果v中的key没有完全的指定所有字段,比如少name或者少id,那么记录能否被成功插入要根据表格创建时的字段限制来决定, 比如少name,那么此记录会插入,只是name字段的值为NULL;如果少id,那么记录不会被插入,因为创建时指定了NOT NULL.

  可以通过以下指令来查看结果:

adb shell执行后进入shell;

cd /data/data/cn.demo.sql

sqlite3 database.db 进入了sqlite操作界面。

.help可以看到命令帮助。
.dump 可以看到数据库中的数据。
  为了方便使用,可以自定义一个insert函数,将值通过参数传入,而ContentValues设置则在函数内部实现。

 
 
1 . public void insert(String id, String name, int age) {
2 . if ( mDb == null ) mDb = getWritableDatabase();
3 . ContentValues v = new ContentValues();
4 . v.put( " id " , id);
上海企业网站设计与制作> 5 . v.put( " name " , name);
6 . if (age > 0 ) v.put( " age " , age);
7 . mDb.insert(TBL_NAME, 上海闵行企业网站制作span>"null上海闵行企业网站设计与制作", v);

  从表格中查询记录

  SQL语句:SELECT column list FROM table WHERE expr ORDER BY column list; 通过SQLiteDatabase类的query()函数: 

 
 
1 . Cursor SQLiteDatabase.query(String table,
2 . String[] columns, String selection, String[] selectionArgs,
3 . String groupBy, String having, String orderBy);

  Parameters:
table 要更新的记录所在的表名。
values 要更新的字段值。
whereClause Where子句。更新哪些记录。
whereArgs Where子句中的'?'替换串。
  执行upda上海徐汇企业网站制作te操作时,如果只给部分字段赋值,那么update后,没有赋值的字段仍然保持原来的值不变。

  从表格中删除记录:

 
 
int SQLiteDatabase.delete(String table, String whereClause, String[]
whereArgs);

  从SQLite的整个创建和查询过程我们可以看出,在Android平台,由于SQLite的特性,一切以文件为主,没有顺序的概念。我们可以通过查询来得到满足条件的记录,通过SQL指令来操作数据库。此外,我们应该熟记Android平台操作SQLite的几个类:SQLiteOpenHelper抽象类、SQLiteDatabase数据库访问类以及SQLiteCursor 查询结构操作类。

目录
相关文章
|
3月前
|
Java Android开发 Swift
安卓与iOS开发对比:平台选择对项目成功的影响
【10月更文挑战第4天】在移动应用开发的世界中,选择合适的平台是至关重要的。本文将深入探讨安卓和iOS两大主流平台的开发环境、用户基础、市场份额和开发成本等方面的差异,并分析这些差异如何影响项目的最终成果。通过比较这两个平台的优势与挑战,开发者可以更好地决定哪个平台更适合他们的项目需求。
130 1
|
4月前
|
IDE Android开发 iOS开发
探索Android与iOS开发的差异:平台选择对项目成功的影响
【9月更文挑战第27天】在移动应用开发的世界中,Android和iOS是两个主要的操作系统平台。每个系统都有其独特的开发环境、工具和用户群体。本文将深入探讨这两个平台的关键差异点,并分析这些差异如何影响应用的性能、用户体验和最终的市场表现。通过对比分析,我们将揭示选择正确的开发平台对于确保项目成功的重要作用。
|
15天前
|
Linux API C#
基于 .NET 开发的多功能流媒体管理控制平台
基于 .NET 开发的多功能流媒体管理控制平台
|
1月前
|
IDE 开发工具 Android开发
移动应用开发之旅:探索Android和iOS平台
在这篇文章中,我们将深入探讨移动应用开发的两个主要平台——Android和iOS。我们将了解它们的操作系统、开发环境和工具,并通过代码示例展示如何在这两个平台上创建一个简单的“Hello World”应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧,帮助你更好地理解和掌握移动应用开发。
68 17
|
2月前
|
机器学习/深度学习 人工智能 Cloud Native
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台。本文深入解析 .NET 的核心优势,探讨其在企业级应用、Web 开发及移动应用等领域的应用案例,并展望未来在人工智能、云原生等方面的发展趋势。
47 3
|
2月前
|
存储 设计模式 编解码
.NET 8.0 通用管理平台,支持模块化、WinForms 和 WPF
【11月更文挑战第5天】本文分析了.NET 8.0 通用管理平台在模块化、WinForms 和 WPF 方面的优势。模块化设计提升了系统的可维护性和可扩展性,提高了代码复用性;WinForms 提供了丰富的控件库和简单易用的开发模式,技术成熟稳定;WPF 支持强大的数据绑定和 MVVM 模式,具备丰富的图形和动画功能,以及灵活的布局系统。
|
3月前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
123 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
4月前
|
开发工具 Android开发 iOS开发
安卓与iOS开发环境对比:选择适合你的平台
【9月更文挑战第26天】在移动应用开发的广阔天地中,安卓和iOS是两大巨头。它们各自拥有独特的优势和挑战,影响着开发者的选择和决策。本文将深入探讨这两个平台的开发环境,帮助你理解它们的核心差异,并指导你根据个人或项目需求做出明智的选择。无论你是初学者还是资深开发者,了解这些平台的异同都至关重要。让我们一起探索,找到最适合你的那片开发天地。
|
8月前
|
存储 数据库连接 数据库
Android数据存储:解释SQLite数据库在Android中的使用。
Android数据存储:解释SQLite数据库在Android中的使用。
101 0
|
7月前
|
数据库 Android开发 数据安全/隐私保护
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
299 2