本文主要是介绍一起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中的数据存储之数据库大结局)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!