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

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

C#使用iText获取PDF的trailer数据的代码示例

《C#使用iText获取PDF的trailer数据的代码示例》开发程序debug的时候,看到了PDF有个trailer数据,挺有意思,于是考虑用代码把它读出来,那么就用到我们常用的iText框架了,所... 目录引言iText 核心概念C# 代码示例步骤 1: 确保已安装 iText步骤 2: C# 代码程

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

k8s搭建nfs共享存储实践

《k8s搭建nfs共享存储实践》本文介绍NFS服务端搭建与客户端配置,涵盖安装工具、目录设置及服务启动,随后讲解K8S中NFS动态存储部署,包括创建命名空间、ServiceAccount、RBAC权限... 目录1. NFS搭建1.1 部署NFS服务端1.1.1 下载nfs-utils和rpcbind1.1

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

Oracle数据库在windows系统上重启步骤

《Oracle数据库在windows系统上重启步骤》有时候在服务中重启了oracle之后,数据库并不能正常访问,下面:本文主要介绍Oracle数据库在windows系统上重启的相关资料,文中通过代... oracle数据库在Windows上重启的方法我这里是使用oracle自带的sqlplus工具实现的方