Android Studio—— SQLite数据库存储

73 阅读3分钟

2、创建 MyHelper 对象,会在本地文件/data/目录下新建一个db文件.

3、设计增删改查功能模块

三、大致过程

四、代码实现

创建 MyHelper 类继承SQLiteHelper
  • 复写onCreate()和onUpgrade()方法

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteOpenHelper;

import androidx.annotation.Nullable;

public class MyHelper extends SQLiteOpenHelper {

public MyHelper(@Nullable Context context) {

//super参数(上下文、数据库名字(base)、游标工厂、版本号)

super(context,"base.db",null, 1);

}

@Override

public void onCreate(SQLiteDatabase db) {

/**

  • SQL语句----CREATE TABLE data: 创建一个表名为data的表

  • 字段-------ID:varchar类型,长度20,不为空,主键 NAME:varchar类型,长度20,不为空

*/

db.execSQL("CREATE TABLE data(ID VARCHAR(20) NOT NULL PRIMARY KEY, NAME VARCHAR(20) NOT NULL)");

}

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

}

}

添加数据
  • 1、创建 MyHelper 对象

  • 2、创建 SQLiteDatavase 对象

  • 3、创建 ContentValues 对象

  • 4、向 ContentValues 对象添加数据

  • 5、调用 insert 函数

//本例子只设计了两个字段(ID, NAME),大家可自行设计

private void Add(String ID, String NAME){

//创建MyHelper类

MyHelper myHelper = new MyHelper(this);

//获取可写对象

SQLiteDatabase db = myHelper.getWritableDatabase();

//创建ContentValues对象存放数据

ContentValues values = new ContentValues();

//添加数据

values.put("ID",ID);

values.put("NAME",NAME);

//将values数据插入到表(data)中

db.insert("data",null,values);

//关闭操作

db.close();

}

删除数据
  • 1、创建 MyHelper 对象

  • 2、创建SQLiteDatavase 对象

  • 3、调用delete函数

//本例子通过唯一标识 ID 删除数据

private void Delete(String ID){

//创建MyHelper类

MyHelper myHelper = new MyHelper(this);

//获取可写对象

SQLiteDatabase db = myHelper.getWritableDatabase();

//delete参数(要操作的表名,条件,参数)

db.delete("data","ID=?", new String[] {ID+""});

//关闭

db.close();

}

修改数据
  • 1、创建 MyHelper 对象

  • 2、创建 SQLiteDatavase 对象

  • 3、创建 ContentValues 对象

  • 4、向 ContentValues 对象赋值

  • 5、调用 update 函数

//本例子通过标识 ID 对 NAME 进行修改数据,大家可自行设计

private void Modify(String ID, String NAME){

//创建MyHelper类

MyHelper myHelper = new MyHelper(this);

//获取可写对象

SQLiteDatabase db = myHelper.getWritableDatabase();

//创建ContentValues对象存放数据

ContentValues values = new ContentValues();

//存放要修改的数据

values.put("NAME",NAME);

//update参数(表名,条件,参数)

db.update("data",values,"ID=?", new String[] {ID});

db.close();

}

查询数据
  • 1、创建 MyHelper 对象

  • 2、创建 SQLiteDatavase 对象

  • 3、创建游标

  • 4、调用 query 函数

  • 5、调用 getString 函数循环获取数据

//本例子通过 ID 查询,大家可自行设定

private void Find(String ID){

MyHelper myHelper = new MyHelper(this);

//获取可读对象

SQLiteDatabase db = myHelper.getReadableDatabase();

//调用query函数查询

Cursor cursor = db.query("data", null, "ID=?", new String[] {ID+""}, null, null ,null);

//判断是否有数据

if (cursor.getCount() != 0){

//循环获取

while (cursor.moveToNext()){

//获取ID,NAME

String id = cursor.getString(cursor.getColumnIndex("ID"));

String name = cursor.getString(cursor.getColumnIndex("NAME"));

//在TextView展示数据

Show.setText(Show.getText().toString()+"\n"+"ID:"+id+" "+"NAME:"+name);

}

}

}

五、功能展示

这里我添加了三个数据(A001,A002,A003),就不完全展示了,大家可以去自行试试

六、db文件

最后

Android学习是一条漫长的道路,我们要学习的东西不仅仅只有表面的 技术,还要深入底层,弄明白下面的 原理,只有这样,我们才能够提高自己的竞争力,在当今这个竞争激烈的世界里立足。

人生不可能一帆风顺,有高峰自然有低谷,要相信,那些打不倒我们的,终将使我们更强大,要做自己的摆渡人。

我把自己这段时间整理的Android最重要最热门的学习方向资料放在了我的GitHub,里面还有不同方向的自学编程路线、面试题集合/面经、及系列技术文章等。

资源持续更新中,欢迎大家一起学习和探讨。