一起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

相关文章

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

Android实现打开本地pdf文件的两种方式

《Android实现打开本地pdf文件的两种方式》在现代应用中,PDF格式因其跨平台、稳定性好、展示内容一致等特点,在Android平台上,如何高效地打开本地PDF文件,不仅关系到用户体验,也直接影响... 目录一、项目概述二、相关知识2.1 PDF文件基本概述2.2 android 文件访问与存储权限2.

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle