安卓 数据库 开发

Android应用开发中,数据库是非常重要的一部分,除了存储和管理数据外,还有不少应用涉及到几个或多个表格之间的相互关系,因此,良好的数据库设计和实现就显得尤为重要了。

一、SQLite数据库

Android 被设计为高性能的移动操作系统,它使用轻量级的 SQLite 数据库来存储应用程序数据。SQLite 是一种免费,开源的数据库引擎,它最初是一个独立的项目,并在多个编程语言,平台和操作系统上使用,包括 Android 中。SQLite 并不是一个完整的数据库服务器,而是一个库,即嵌入式库,由一个小型的,自包含的,正式的 ANSI C 的源码库组成,它在需要时可以动态链接库。SQLite 旨在提供一种嵌入式 ACID 数据库,适用于从小型的嵌入式设备到超大型的信息库的服务器情景。

下面是 Android 中简单使用 SQLite 的例子:

1.创建一个 Helper 从而打开/创建一个数据库

public class DBHelper extends SQLiteOpenHelper {

private static final String DB_NAME = "mydata.db";

private static final int DB_VERSION = 1;

public static final String TABLE = "t_person";

public DBHelper(Context context) {

super(context, DB_NAME, null, DB_VERSION);

}

@Override

public void onCreate(SQLiteDatabase db) {

db.execSQL("CREATE TABLE " + TABLE + "(_id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR, age INTEGER)");

}

@Override

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

db.execSQL("DROP TABLE IF EXISTS " + TABLE);

onCreate(db);

}

}

在MyApplication里初始化数据库

public class MyApplication extends Application {

public static DBHelper dbHelper;

@Override

public void onCreate() {

super.onCreate();

dbHelper = new DBHelper(this);

}

@Override

public void onTerminate() {

super.onTerminate();

dbHelper.close();

}

}

在Activity里执行SQL语句

Button bt_insert = (Button)findViewById(R.id.bt_insert);

bt_insert.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View view) {

SQLiteDatabase db = MyApplication.dbHelper.getWritableDatabase();

String sql = "INSERT INTO " + DBHelper.TABLE + "(name,age) values (?,?)";

Object[] bindArgs = {"Tom",12};

db.execSQL(sql, bindArgs);

}

});

2.数据库操作语句

SQLite 通过 SQL 语句进行数据库操作,包括增、删、改和查四个基本操作,下面列出一些 SQLite 常用的 SQL 语句:

创建表格: CREATE TABLE table_name (column_name data_type);

删除表格: DROP TABLE table_name;

清空数据表: DELETE FROM table_name;

查询数据: SELECT column1, column2, ... FROM table_name;

插入数据: INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...);

更新数据: UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE some_column = some_value;

删除数据: DELETE FROM table_name WHERE some_column = some_value;

二、数据库基本操作示例

1.插入数据

SQLiteDatabase db = dbHelper.getWritableDatabase();

ContentValues values = new ContentValues();

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

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

db.insert(DBHelper.TABLE, null, values);

db.close();

2.获取数据

SQLiteDatabase db = dbHelper.getReadableDatabase();

Cursor cursor = db.query(DBHelper.TABLE, new String[] { "_id", "name", "age" }, null, null, null, null, null);

if (cursor.moveToFirst()) {

do {

int idIndex = cursor.getColumnIndex("_id");

int id = cursor.getInt(idIndex);

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

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

//代码处理...

} while (cursor.moveToNext());

}

3.修改数据

SQLiteDatabase db = dbHelper.getWritableDatabase();

ContentValues values = new ContentValues();

values.put("age", 20);

db.update(DBHelper.TABLE, values, "name = ?", new String[] { "Tom" });

db.close();

4.删除数据

SQLiteDatabase db = dbHelper.getWritableDatabase();

db.delete(DBHelper.TABLE, "_id = ?", new String[] { "1" });

db.close();

三、总结

Android中的 SQLite 数据库是一款轻量级数据库,适用于中小型的数据库应用,它支持 SQL 语句。在使用 SQLite 数据库时,应该遵循数据库设计的一些基本原则,如遵循约定,不重复,在设计时应该考虑未来的扩展性和变更,保持简单并且易于维护。以上内容只是数据库知识的一个简要介绍,希望能对你有所帮助。


相关知识:
安卓12适配名单miui开发版
安卓12是最近谷歌推出的新操作系统版本,也是一些手机厂商相继进行适配工作的版本。其中,小米旗下的MIUI开发版也进行了适配工作,并且发布了适配名单。本文将从原理和详细介绍两个方面对小米MIUI开发版安卓12适配名单进行解析和阐述。一、适配原理适配是指将一个
2023-05-23
安卓10进入开发者模式进不了
在安卓系统中,开发者模式提供给开发者一些高级调试选项和系统级别的控制,而对普通用户来说,进入开发者模式也有一些小技巧。安卓10进入开发者模式有些不同,本文将详细介绍这个进程的原理和方法。## 安卓10开发者模式简介安卓10在开发者模式上相较于之前的版本没有
2023-05-23
vs开发安卓还是as开发
在移动应用领域,安卓应用的开发已经成为了一种非常普遍的需求。而在开发安卓应用的时候,程序员们也会面临一个选择:使用 Visual Studio 还是使用 Android Studio 进行开发。Visual Studio(VS)是由微软公司开发的一款集成开
2023-05-23
oppo手机安卓11开发者选项在哪
开发者选项是Android系统中一项非常重要的功能,它可以让用户扩展手机设置选项,以实现更多的功能和特性。在OPPO手机Android 11系统中,开发者选项位置稍微有些不同,但也非常容易找到,本篇文章将为你详细介绍。一、开启开发者选项开启开发者选项首先需
2023-05-23
java开发安卓app和web的区别
Java是一种面向对象的编程语言,在软件开发领域中具有广泛应用。Java可以用于开发不同类型的应用程序,包括Android应用和Web应用程序。这篇文章将重点讨论Java开发安卓应用和Web应用程序的区别。1. 应用程序开发目的和用户需求安卓应用通常是为便
2023-05-23
as开发安卓账单
Android的账单开发需要使用AS(Android Studio)进行开发。AS是Android开发平台标配的开发工具,开发者可以在AS上进行Android应用程序的开发,包括开发安卓账单。在这篇文章中,我们将详细介绍如何开发安卓账单。1.创建项目使用A
2023-05-23
anddev安卓开发
AndDev是一个提供安卓开发相关知识的开发者社区。该社区聚集了众多安卓开发人员,同时也为安卓开发人员提供了许多帮助手册和教程,是安卓开发者不可错过的资源。安卓开发是一项非常有前途的技术领域。作为一个安卓开发者,您可以开发不同领域的APP,包括社交,工具,
2023-05-23
安卓app开发公司哪家好
在选择一家安卓App开发公司时,需要考虑以下几个因素:1. 经验和技能:选择经验丰富、技术实力强、专业性强、熟练掌握多种技术工具和技能的公司非常重要。这可以保证你的App不仅具有稳定性和安全性,同时还能保证App的界面设计、交互等用户体验方面更优秀。2.
2023-04-28
安卓app定制开发哪个好
安卓应用定制开发涉及的领域非常广泛,不同的开发工具和技术适用于不同的需求。以下是一些知名的安卓App定制开发工具和技术,根据您的具体需求和技能水平,您可以选择其中之一来进行开发。1. Android StudioAndroid Studio是谷歌官方支持的
2023-04-28
北京安卓app开发报价
北京安卓App开发报价(原理或详细介绍)在当今科技蓬勃发展的时代,手机App已经成为了我们生活中不可或缺的一部分。随着智能手机的普及,安卓App的需求也越来越大。在本文中,我们将讨论关于北京安卓App开发的报价以及安卓App开发的原理和详细介绍。一、北京安
2023-04-28
xe开发安卓和苹果app怎么样
在现代移动开发领域,有许多技术和框架可以让你构建一个适用于Android和iOS平台的应用。其中之一就是Xamarin.Forms(通常简称为XE)。本教程将详细介绍如何使用Xamarin.Forms开发Android和iOS应用。Xamarin.Form
2023-04-28
h5开发的app可以用安卓平台吗
当然可以!H5开发的App可以在安卓平台上使用。H5开发指的是基于HTML5技术构建的应用程序。HTML5为开发者提供了许多方便的功能,如Canvas渲染、音视频播放、地理位置等。利用这些功能,开发者可以创建出丰富的多媒体应用,实现良好的用户体验。现在让我
2023-04-28
©2015-2023 安卓益APP Anzhuoe.com 蜀ICP备17007734号-1