Android Studio—— SQLite数据库存储


  • 注重版权,转载请注明原作者和原文链接
  • 作者:Bald programmer

一、介绍

在 Android 开发中,我们需要存储大量的数据,用户信息、聊天信息、本地记录等等.

而 Android 系统提供了 SQLite 数据库存储,SQLite 数据库是一款轻型的数据库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎

SQLite数据库现在经常用到,如聊天记录存储、购买商品记录等等.

二、实现原理

1、创建 MyHelper 类继承SQLiteOpenHelper类,复写onCreate()方法和onUpgrade()方法.

方法作用
onCreate()执行SQL语句,创建表
onUpgrade数据库版本号增加

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文件

创建 MyHelper 对象的时候会产生一个 db 文件,想查看自己数据的话可以调出 db 文件,通过SQLite工具打开查看

(1)依次点击 View -->> Tool Windows -->> Device File Explorer

(2)这时候在右边会显示目录,依次点击 data -->> data -->> com.example.你的包名(这里我的是ceshi2)

(3)找到自己的目录之后,点击 databases,就能看的自己的db文件

在这里插入图片描述

(4)右键点击 Save as 保存到一个地方,打开SQlite工具,点击左上角的打开数据库

(6)找到刚刚保存的地址,选择db文件,点击打开,就能看到数据了

在这里插入图片描述

七、结尾

注:如没有SQLite Expert Professional 工具的,可以点击链接自行下载 官网下载

本次案例只涉及到简单的增删改查,并没有设计逻辑语句,先让大家熟悉一下SQLite的操作方法

后续会出一篇 SQLite实战教学(账号注册、密码判断、账号检测、密码修改等)

本次案例源码可以点击下方链接免费下载

https://download.csdn.net/download/weixin_47971206/18801887


  • 本次文章分享就到这,有什么疑问或有更好的建议可在评论区留言,也可以私信我
  • 感谢阅读~

### 创建和管理 SQLite 数据库 #### 初始化数据库连接 为了在 Android 应用程序中使用 SQLite 数据库,首先需要创建一个继承自 `SQLiteOpenHelper` 的类。此类用于处理数据库的创建以及版本管理。 ```java public class MySqliteOpenHelper extends SQLiteOpenHelper { public static final String DATABASE_NAME = "example.db"; private static final int VERSION = 1; public MySqliteOpenHelper(Context context) { super(context, DATABASE_NAME, null, VERSION); } @Override public void onCreate(SQLiteDatabase db) { // 当首次访问数据库时执行此方法,在这里可以定义表结构并创建表格 } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // 如果应用程序升级导致数据库版本变化,则在此处处理旧版到新版的数据迁移逻辑 } } ``` 通过上述代码片段可以看到,当实例化 `MySqliteOpenHelper` 类的对象后,可以通过调用其父类的方法获取可读写的数据库对象[^2]: ```java final MySqliteOpenHelper dbHelper = new MySqliteOpenHelper(MainActivity.this); SQLiteDatabase db = dbHelper.getWritableDatabase(); ``` #### 创建数据库与表单 一旦获得了数据库对象,便可以在 `onCreate()` 方法内编写 SQL 命令来构建所需的表单。例如,假设想要建立一张存储用户信息(姓名、年龄)的表单: ```sql String CREATE_TABLE_USERINFO = "CREATE TABLE USER_INFO (" + "_id INTEGER PRIMARY KEY AUTOINCREMENT," + "name TEXT NOT NULL," + "age INTEGER)"; db.execSQL(CREATE_TABLE_USERINFO); ``` 这段 SQL 将会在初次启动应用并且尚未存在名为 `USER_INFO` 表格的情况下被执行,从而完成新表的创建工作[^1]。 #### 更新现有表单结构 如果之后希望向已有的表单增加新的列项,可在 `onUpgrade()` 函数内部实现相应的变更操作。比如给前述提到的 `USER_INFO` 添加一个新的字段——性别: ```sql if (oldVersion < 2 && newVersion >= 2){ db.execSQL("ALTER TABLE USER_INFO ADD COLUMN gender TEXT"); } ``` 这行语句仅会在检测到当前安装的应用版本低于指定数值时才会生效,以此确保不会重复修改相同的表结构。 #### 查看数据库文件 对于开发者而言,有时可能需要直观地观察所创建的 SQLite 文件内容。此时可通过 Android Studio 自带的功能直接浏览项目内的 `.db` 或者其他扩展名表示的本地数据库文件;不过初访这些资源可能会遇到编码问题,提示是否允许安装额外的支持工具以改善体验,通常推荐接受该提议以便更好地管理和调试数据[^4]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Open开袁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值