免费试用

中文化、本土化、云端化的在线跨平台软件开发工具,支持APP、电脑端、小程序、IOS免签等等

app 开发 本地数据库

在移动应用开发中,由于需要处理大量的数据,因此使用本地数据库来存储数据是非常常见的。本地数据库与远程数据库不同,它是存储在设备本地的一种数据存储方式。本地数据库有很多种,其中 SQLite 是一种非常受欢迎的本地数据库,它是一种轻量级的数据库,支持跨平台操作,可以在 iOS、Android 和 Windows 上运行。

一、SQLite 数据库的使用方法

1. 引入 SQLite 库

在应用程序的 build.gradle 文件中加入以下代码:

```

dependencies {

compile 'com.facebook.stetho:stetho:1.5.0'

compile 'com.facebook.stetho:stetho-okhttp3:1.5.0'

compile 'com.squareup.okhttp3:okhttp:3.5.0'

compile 'com.squareup.okhttp3:logging-interceptor:3.5.0'

compile 'com.facebook.stetho:stetho-js-rhino:1.5.0'

compile 'com.facebook.stetho:stetho-js:1.5.0'

compile 'com.facebook.stetho:stetho-common:1.5.0'

compile 'com.squareup.retrofit2:retrofit:2.3.0'

compile 'com.squareup.retrofit2:converter-gson:2.3.0'

compile 'net.zetetic:android-database-sqlcipher:3.5.9@aar'

}

```

2. 创建数据库

首先要创建 DBhelper 类,DBhelper 继承自 SQLiteOpenHelper:

```

public class DBhelper extends SQLiteOpenHelper {

public DBhelper(Context context, String name, CursorFactory factory, int version) {

super(context, name, factory, version);

}

@Override

public void onCreate(SQLiteDatabase db) {

db.execSQL("create table if not exists user(id integer primary key autoincrement,name varchar(10),age varchar(10))");

}

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

//升级数据库

}

}

```

创建好 DBhelper 后,在 Activity 中创建一个 DBhelper 的实例:

```

mDbhelper = new DBhelper(this, "test.db", null, 1);

```

3. 数据库插入数据

插入数据可以通过 ContentValues 的方式实现:

```

ContentValues values = new ContentValues();

values.put("name", "Java");

values.put("age", "10");

mDbhelper.getWritableDatabase().insert("user", null, values);

```

或者通过 SQL 语句的方式实现:

```

mDbhelper.getWritableDatabase().execSQL("insert into user(name,age) values('Java',10)");

```

4. 数据库查询数据

查询数据可以通过 Cursor 对象实现:

```

String sql = "select * from user";

Cursor cursor = mDbhelper.getWritableDatabase().rawQuery(sql, null);

while (cursor.moveToNext()) {

int id = cursor.getInt(cursor.getColumnIndex("id"));

String name = cursor.getString(cursor.getColumnIndex("name"));

String age = cursor.getString(cursor.getColumnIndex("age"));

Log.i(TAG, "id=" + id + ",name=" + name + ",age=" + age);

}

cursor.close();

```

5. 数据库更新数据

更新数据可以通过 ContentValues 的方式实现:

```

ContentValues values = new ContentValues();

values.put("age", 20);

mDbhelper.getWritableDatabase().update("user", values, "name=?", new String[]{"Java"});

```

或者通过 SQL 语句的方式实现:

```

String sql="update user set age=20 where name='Java'";

mDbhelper.getWritableDatabase().execSQL(sql);

```

6. 数据库删除数据

删除数据可以通过 SQL 语句的方式实现:

```

String sql="delete from user where name='Java'";

mDbhelper.getWritableDatabase().execSQL(sql);

```

二、SQLite 数据库的原理

SQLite 是一个轻量级的数据库,跟其他的数据库相比,它的设计体系更加紧凑。它的数据库引擎是以 C 语言实现的,整个数据库可以存储在一个文件里面,不需要一个额外的服务器程序来协助存储管理。SQLite 的设计目标是使得移动设备和嵌入式设备能够高效地存储数据和查询数据,因此,SQLite 的主要应用场景是移动应用和嵌入式设备。

SQLite 数据库的文件结构非常简洁,包含 5 种文件结构:

1. 文件头

2. 数据库页

3. 数据页

4. 索引页

5. 跟踪页

SQLite 的查询语言采用的是 SQL92 标准,但是 SQLite 支持的 SQL 语法的一部分是是与 SQL92 不兼容的。SQLite 具有正确的、无锁的并发操作,能够确保多个进程和线程同时访问数据库而不出现数据损坏的情况。

在 SQLite 数据库中,表达数据模型的是查询计划,查询计划是一颗查询树,它表示了查询过程中所需的数据流。每个节点都有一个输入和一个输出,输入数据会处理产生输出, 最终的节点会把所需的数据输入到查询结果里面。

总结

本文介绍了使用 SQLite 数据库的方法和 SQLite 数据库的原理,SQLite 作为一个轻量级的数据库,非常适合在移动应用和嵌入式设备中使用。使用 SQLite 数据库可以非常方便地存储处理数据,并且保证了数据的稳定性和安全性。相信通过本文的介绍,读者对 SQLite 数据库的使用和原理有了更深入的了解,可以更加熟练地在开发中使用这个工具。


相关知识:
如何覆盖之前开发的app
在开发App过程中,经常会遇到需要覆盖之前开发的App的情况。这种情况可能由于需要更新App版本、修复已知的bug或者重新设计App界面等原因引起。覆盖之前开发的App有两种常用的方式:直接覆盖和增量覆盖。1. 直接覆盖直接覆盖是指将新版本的App直接覆盖
2024-01-10
启汇app开发
启汇app是一款致力于推动国内文创产业发展的移动应用程序。它的主要功能包括展示文创产品、提供文创资讯、在线购买、社交分享等。在启汇app的开发过程中,涉及到了多种技术和工具,下面将对其进行详细介绍。1. 开发语言与框架启汇app的开发语言主要是使用了Jav
2024-01-10
app开发软件工具文档介绍内容
APP开发是指使用特定的开发工具和技术,设计和开发适用于移动设备的应用程序。这些应用程序可以在手机、平板电脑和其他移动设备上运行,为用户提供各种功能和服务。在APP开发过程中,开发者需要选择合适的开发软件工具,以提高开发效率和质量。本文将介绍几种常用的AP
2023-06-29
app开发和网页开发
APP开发和网页开发是现代互联网领域中最为常见的两种开发方式,它们分别针对不同的应用场景和用户需求。在本文中,我们将详细介绍这两种开发方式的原理和特点。一、APP开发1. 原理APP是指应用程序,是一种安装在移动设备(如手机、平板电脑)上的软件。APP开发
2023-06-29
app程序开发需求
随着智能手机和平板电脑等移动设备的普及,移动应用程序也越来越受欢迎。一个好的移动应用可以为用户带来很多便利和乐趣,也可以为企业带来更多的收益。在这样的背景下,app程序开发成为了一个非常重要的领域。app程序是一种面向移动设备开发的应用程序。与传统的桌面应
2023-05-06
app功能开发公司
App功能开发公司,是致力于为企业、机构及个人提供App开发服务的专业技术服务公司。随着智能手机、平板电脑等移动设备的普及,绝大多数人开始使用App进行生活、工作方面的各种事务。因此,App功能开发公司为满足用户的需求,迅速崛起。App功能开发公司的主要业
2023-05-06