安卓 数据库 开发

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 数据库时,应该遵循数据库设计的一些基本原则,如遵循约定,不重复,在设计时应该考虑未来的扩展性和变更,保持简单并且易于维护。以上内容只是数据库知识的一个简要介绍,希望能对你有所帮助。


相关知识:
安卓9
安卓9.0开发板是一种可供开发人员学习或测试安卓应用程序的硬件平台。该开发板与安卓智能手机或平板电脑很相似,但是它具有更高的灵活性和易于定制的特点。安卓9.0开发板的基础是安卓操作系统的核心模块(Android Open Source Project, A
2023-05-23
安卓10开发者开启自由窗口
自由窗口是安卓10新增的功能,它允许用户在一个应用程序内部打开多个窗口。这个功能不仅可以提高用户的工作效率,而且还可以增加用户对应用程序的使用体验。下面是自由窗口的原理和详细介绍:一、原理自由窗口的实现原理是将应用程序的窗口管理器复制一份,然后在该复制的窗
2023-05-23
vscode开发安卓锁屏
随着智能手机的普及,很多人在日常生活中都会使用安卓系统的手机。而其中一个比较重要的功能就是锁屏。本文将详细介绍如何使用VScode进行安卓锁屏的开发。首先,我们需要了解一下安卓锁屏背后的原理。安卓系统中的锁屏功能是通过KeyguardService服务实现
2023-05-23
google 安卓开发
安卓(Android)是由Google开发的基于Linux的移动操作系统,它为移动设备提供了一个广泛的应用程序生态系统和开发工具集。安卓操作系统的核心是Linux内核,负责硬件驱动、内存管理、系统调度等基本功能。上层则是一些库和软件框架,提供了各种功能接口
2023-05-23
eclipse如何开发安卓
Eclipse 是一个常用的集成开发环境(IDE),可以在其中进行 Java 的开发。通过插件的安装,Eclipse 也可以进行安卓的开发。Eclipse 在安卓开发中的主要作用是提供一个集成的环境,方便开发人员进行代码编写、调试、构建及测试等工作。本文将
2023-05-23
csdn安卓开发实训选题
近年来,随着智能手机的普及,移动端软件的开发变得越来越热门,其中安卓开发是移动端软件开发的重要分支。针对安卓开发这个选题,我认为可以探讨以下几个方向。一、安卓开发语言Java与Kotlin探讨安卓开发语言不同于Web端开发,需要使用Java或Kotlin语
2023-05-23
自己开发的安卓app图片加载不出来
在安卓开发中,图片加载不出来可能跟以下几个因素有关:1. 权限问题:Android系统需要我们获取一些特殊权限才能够访问一些敏感数据。比如访问摄像头、读写SD卡等敏感操作,需要在AndroidManifest.xml文件中配置相应的权限。如果我们的代码中没
2023-04-28
安卓开发新闻资讯类app
在本教程中,我们将介绍如何制作一个基本的新闻资讯类App,这个App可以抓取并展示实时的新闻信息。我们将使用Android Studio进行开发,体验从头创建一个安卓App的过程。该教程主要针对安卓开发新手,我们将详细阐述每一个步骤。**准备工作**1.
2023-04-28
安卓商城app开发系统企业定制
安卓商城app开发系统是一种集成商城购物、订单管理、支付等功能的安卓应用程序开发系统,如今很多企业都会利用这样的开发系统进行自己平台的应用程序开发,从而提升企业的品牌形象和销售额。该系统的企业定制是基于现有的安卓商城app开发系统的功能进行二次开发和定制,
2023-04-28
安卓app消息推送开发
标题:安卓APP消息推送开发:原理与详细介绍第一部分:消息推送是什么?1.1 消息推送介绍消息推送(Push Notification)是一种在移动应用内发送实时消息的技术。安卓APP开发者可以借助消息推送通知用户有关新功能、更新或其他有价值的信息,从而提
2023-04-28
安卓app如何开发
安卓应用开发是一个涉及计算机编程、设计和软件开发的过程,其最终目标是在Android平台上构建应用程序。安卓是由Google开发的一个操作系统,使用安卓开发工具(如Android Studio)、编程接口(如Android SDK)和语言(如Java、Ko
2023-04-28
如何通过找到安卓app找到开发商
在这篇文章中,将详细介绍如何找到安卓应用的开发商。通过以下几种方法,即可找到应用的开发商,了解更多关于开发团队和应用来源的信息。1.应用商店(如Google Play商店)若要在Google Play商店中查找app的开发商,请按照以下步骤操作:a.打开G
2023-04-28
©2015-2023 安卓益APP Anzhuoe.com 蜀ICP备17007734号-1