一起Talk Android吧(第二百三十一回:Android中的数据存储之数据库大结局)

本文主要是介绍一起Talk Android吧(第二百三十一回:Android中的数据存储之数据库大结局),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

各位看官们大家好,上一回中咱们说的是Android中数据存储之数据库的例子,这一回咱们继续说该例子。闲话休提,言归正转。让我们一起Talk Android吧!

看官们,我们在前面章回中介绍了如何创建数据库,以及操作数据库中的数据,下面是综合练习的时候了,我们先建立一个工程,并且在工程的布局文件中添加一些按钮,然后给这些按钮添加事件监听器。监听器的主要内容就是操作数据库中的数据。监听器不同,具体的操作也不同,这些操作包含插入,更新,删除,查询数据;下面是完整的代码,请大家参考:

package com.example.talk8.blogappall;import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.DatabaseErrorHandler;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.widget.Button;public class ActivityDatabase extends AppCompatActivity {//数据库名称,表名称以及数据库版本号相关的变量private static final String TAG = "DataStorage";private static final String DB_NAME = "schoolA";private int DBVersion = 1;//数据库和其Helper类的变量private SchloolDB mSchloolDBHelper ;private SQLiteDatabase mDatabase;//操作数据库的各种按钮private Button mCreateDB;private Button mInsertData;private Button mUpdateData;private Button mDeleteData;private Button mQueryData;//创建数据库中的表,名字是学生,包含姓名,年龄,班级三个信息字段private static final String CREATE_STUDENT = "create table Student("+ "id integer primary key autoincrement,"+ "name text,"+ "age integer,"+ "class text )";@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_database);//关联各种操作数据库的按钮mCreateDB = (Button)findViewById(R.id.create_db);mInsertData = (Button) findViewById(R.id.insert_data);mUpdateData = (Button) findViewById(R.id.update_data);mDeleteData = (Button) findViewById(R.id.delete_data);mQueryData = (Button) findViewById(R.id.query_data);//为各种操作数据库的按钮添加事件监听器mCreateDB.setOnClickListener(v -> CreateDB(this));mInsertData.setOnClickListener(v ->InsertData());mUpdateData.setOnClickListener(v ->UpdateData());mDeleteData.setOnClickListener(v ->DeleteData());mQueryData.setOnClickListener(v ->QueryData());}@Overrideprotected void onDestroy() {super.onDestroy();if(mSchloolDBHelper != null && mDatabase != null) {Log.i(TAG, "onDestroy: Close DB");mDatabase.close();mDatabase = null;mSchloolDBHelper = null;}}// 创建SQLiteOpenHelper的子类并且重写构造方法和onCreeate()等回调方法class SchloolDB extends SQLiteOpenHelper {public SchloolDB(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {super(context, name, factory, version);}public SchloolDB(Context context, String name,SQLiteDatabase.CursorFactory factory, int version, DatabaseErrorHandler errorHandler) {super(context, name, factory, version, errorHandler);}@Overridepublic void onCreate(SQLiteDatabase db) {Log.i(TAG, "onCreate of DB");db.execSQL(CREATE_STUDENT);}@Overridepublic void onOpen(SQLiteDatabase db) {super.onOpen(db);Log.i(TAG, "onOpen of DB");}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {Log.i(TAG, "onUpgrade of DB");}}public void CreateDB(Context context) {//创建自定义子类的对象,通过该对象创建具体的数据库Log.i(TAG, "CreateDB: Create and open DB");mSchloolDBHelper = new SchloolDB(context,DB_NAME,null,DBVersion);mDatabase = mSchloolDBHelper.getWritableDatabase();}//向数据库中的Student表中插入数据public void InsertData() {Log.i(TAG, "InsertData: ");ContentValues values = new ContentValues();values.put("name","Jame");values.put("age","10" );values.put("class","Class1" );mDatabase.insert("Student",null , values);values.put("name","Store");values.put("age","12" );values.put("class","Class2" );mDatabase.insert("Student",null , values);}//更新数据库Student表中的数据//查找到表格中名字为Jame的学生,把它的班级从Class1更新为Class2public void UpdateData() {Log.i(TAG, "UpdateData: ");ContentValues values = new ContentValues();values.put("class", "Class2");mDatabase.update("Student", values, "name= ?",new String[] {"Jame"});}//删除数据库Student表中的数据//查找到表格中名字为Jame的学生,把它所有的数据从表中删除public void DeleteData() {Log.i(TAG, "DeleteData: ");mDatabase.delete("Student","name= ?",new String[]{"Jame"});}//查询数据库Student表中的数据//没有使用查询条件,因此查找到表中所有的内容public void  QueryData() {Log.i(TAG, "QueryData: ");Cursor cursor = mDatabase.query("Student",null ,null, null, null, null, null);if(cursor.moveToFirst()) {do{String name = cursor.getString(cursor.getColumnIndex("name"));int age = cursor.getInt(cursor.getColumnIndex("age"));String className = cursor.getString(cursor.getColumnIndex("class"));Log.i(TAG,"Name: "+name+" Age: "+ age +" Class: "+className);}while (cursor.moveToNext());}cursor.close();}
}

下面是程序的运行结果,请大家参考:

 //按下CreateDatabase按钮创建数据库I/DataStorage: CreateDB: Create and open DBI/DataStorage: onCreate of DBI/DataStorage: onOpen of DB//按下InsertData的按钮向数据库中插入数据I/DataStorage: InsertData: //按下QueryData的按钮查询数据库中的数据,数据已经被插入I/DataStorage: QueryData: I/DataStorage: Name: Jame Age: 10 Class: Class1I/DataStorage: Name: Store Age: 12 Class: Class2//按下DeleteData的按钮删除数据库中的数据I/DataStorage: DeleteData: //按下QueryData的按钮查询数据库中的数据,数据已经被删除I/DataStorage: QueryData: I/DataStorage: Name: Store Age: 12 Class: Class2//按下InsertData的按钮向数据库中插入数据I/DataStorage: InsertData: //按下QueryData的按钮查询数据库中的数据,数据已经被插入I/DataStorage: QueryData: I/DataStorage: Name: Store Age: 12 Class: Class2I/DataStorage: Name: Jame Age: 10 Class: Class1I/DataStorage: Name: Store Age: 12 Class: Class2//按下UpdateData的按钮更新数据库中的数据,数据已经被更新I/DataStorage: UpdateData: I/DataStorage: QueryData: I/DataStorage: Name: Store Age: 12 Class: Class2I/DataStorage: Name: Jame Age: 10 Class: Class2I/DataStorage: Name: Store Age: 12 Class: Class2//销毁Activity时关闭数据库I/DataStorage: onDestroy: Close DB

看官们,关于数据库的操作我们全部介绍完了,我们使用的是SQLite相关类以及类中的方法,不过在新版本中官方不推荐直接使用SQLite操作数据库,而是使用ROOM来操作数据库,因为Room在SQLite上提供了一个抽象层,以便在充分利用SQLite的强大功能的同时,能够流畅地访问数据库。因此,我也推荐大家使用数据库的时候过渡到ROOM。关于ROOM的内容比较多,而且我在工作中也没有使用过,因此先不分享这方面的经验了,感兴趣的看官可以参考官方文档来学习。

各位看官,关于Android中数据存储之数据库的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!

这篇关于一起Talk Android吧(第二百三十一回:Android中的数据存储之数据库大结局)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/800069

相关文章

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

MySQL中删除重复数据SQL的三种写法

《MySQL中删除重复数据SQL的三种写法》:本文主要介绍MySQL中删除重复数据SQL的三种写法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录方法一:使用 left join + 子查询删除重复数据(推荐)方法二:创建临时表(需分多步执行,逻辑清晰,但会

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

C#实现文件读写到SQLite数据库

《C#实现文件读写到SQLite数据库》这篇文章主要为大家详细介绍了使用C#将文件读写到SQLite数据库的几种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录1. 使用 BLOB 存储文件2. 存储文件路径3. 分块存储文件《文件读写到SQLite数据库China编程的方法》博客中,介绍了文

Oracle Expdp按条件导出指定表数据的方法实例

《OracleExpdp按条件导出指定表数据的方法实例》:本文主要介绍Oracle的expdp数据泵方式导出特定机构和时间范围的数据,并通过parfile文件进行条件限制和配置,文中通过代码介绍... 目录1.场景描述 2.方案分析3.实验验证 3.1 parfile文件3.2 expdp命令导出4.总结

更改docker默认数据目录的方法步骤

《更改docker默认数据目录的方法步骤》本文主要介绍了更改docker默认数据目录的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1.查看docker是否存在并停止该服务2.挂载镜像并安装rsync便于备份3.取消挂载备份和迁

使用JavaScript操作本地存储

《使用JavaScript操作本地存储》这篇文章主要为大家详细介绍了JavaScript中操作本地存储的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录本地存储:localStorage 和 sessionStorage基本使用方法1. localStorage