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

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手