我的编程空间,编程开发者的网络收藏夹
学习永远不晚

AndroidSharePreferences与数据库SQLite存储实现方法介绍

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

AndroidSharePreferences与数据库SQLite存储实现方法介绍

Android数据存储几种方式

  • SharePreferences
  • 数据库SQLite
  • 存储卡的文件操作
  • Application

一、共享参数

SharePreferences是Android的一个轻量级存储工具,采用的存储结构是Key-Value的键值对方式。

共享参数的存储介质是符合XML规范的配置文件,保存路径是:/data/data/应用包名/shared_prefs/文件名.xml

使用场景

共享参数主要适用于如下场合:

  • 简单且孤立的数据,若是复杂且相互间有关的数据,则要保存在数据库中。
  • 文本形式的数据,若是二进制数据,则要保存在文件中。
  • 需要持久化存储的数据,在APP退出后再次启动时,之前保存的数据仍然有效。

实际开发,共享参数经常存储的数据有APP的个性化配置信息、用户使用APP的行为信息、临时需要保存的片段信息等。

例:输入姓名保存到共享参数,重新打开应用会自动输入到输入框。

XML文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="5dp">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:orientation="horizontal">
        <TextView
            android:id="@+id/tv_name"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:gravity="center"
            android:text="姓名"
            android:textSize="17sp"/>
        <EditText
            android:id="@+id/et_name"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:hint="请输入姓名"
            android:inputType="text"
            android:textSize="17sp"/>
</LinearLayout>
    <Button
        android:id="@+id/btn_save"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="保存到共享参数"
        android:textSize="17sp"/>
</LinearLayout>

java文件

public class ShareWriteActivity extends AppCompatActivity implements View.OnClickListener {
    private EditText et_name;
    private SharedPreferences preferences;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_share_write);
        et_name = findViewById(R.id.et_name);
        findViewById(R.id.btn_save).setOnClickListener(this);
//      点击保存共享参数则保存数据
        preferences = getSharedPreferences("config", Context.MODE_PRIVATE);
//      打开应用会检测是否有保存过的数据
        reload();
    }
    private void reload() {
        String name = preferences.getString("name",null);
        if(name != null){
            et_name.setText(name);
        }
    }
    @Override
    public void onClick(View view) {
        String name = et_name.getText().toString();
        SharedPreferences.Editor editor = preferences.edit();
        editor.putString("name",name);
        editor.commit();
    }
}

二、数据库SQLite

SQLite是一种小巧的嵌入式数据库,使用方便、开发简单,由于属于轻型数据库,不涉及复杂的数据控制操作,因此App开发只用到数据定义和数据操纵两类SQL。

1、数据定义语言(DDL)

它描述了怎样变更数据实体的框架结构,主要包括三种操作:创建表格、删除表格、修改表结构。

(1)创建表格

语法:CREATE TABLE IF NOT EXISTS 表格名称();

说明:

  • SQL语句不区分大小写。
  • 支持整型INTEGER,长整型LONG,字符串VARCHAR,浮点数FLOAT,但不支持布尔类型,如果使用布尔类型,true转换为1,false转换为0。
  • 为避免重复建表,应加上IF NOT EXISTS关键词。
  • 建表时需要唯一标识字段,它的字段名为id。

例:

CREATE TABLE IF NOT EXISTS user_info(
    id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
    name VARCHAR NOT NULL
);

(2)删除表格

语法:DROP TABLE IF EXISTS 表格名称;

例:

DROP TABLE IF EXISTS user_info;

(3)修改表结构

语法:ALTER TABLE 表格名称 修改操作;

说明:

SQLite只支持增加字段,不支持修改字段,也不支持删除字段,对于字段增加操作,需要在alter之后补充add命令。

例:

ALTER TABLE user_info ADD COLUMN phone VARCHAR;

2、数据操纵语言(DML)

描述了怎么样处理数据实体的内部记录,表格记录的操作类型包括添加、删除、修改、查询四类。

(1)添加记录

语法:INSERT INTO 表格名称( 以逗号分隔的字段名列表 ) VALUES (以逗号分隔的字段值列表);

例:

INSERT INTO user_info (name,age,height) VALUES ('张',20,64);

(2)删除记录

语法:DELETE FROM 表格名称 WHERE 查询条件;

例:

DELETE FROM user_info WHERE name = '张';

(3)修改记录

语法:UPDATE 表格名称 SET 字段名=字段值 WHERE 查询条件;

例:

UPDATE user_info SET married=1 WHERE name='张';

(4)查询记录

语法:SELECT 以逗号分隔的字段名列表 FROM 表格名称 WHERE 查询条件;

例:

SELECT name FROM user_info WHERE name='张';

查询操作除了比较字段值条件外,还可对查询结果排序“ORDER BY 字段名 ASC或DESC”

例:

SELECT * FROM user_info ORDER BY age ASC;

三、数据库管理器SQLiteDatabase

若要在java代码中操纵SQLite,需专门的工具类,SQLiteDatabase是Android提供的SQLite数据库管理器,可调用openOrCreateDatabase方法获取数据库实例。

获取数据库实例后,可开展各项操作,提供了若干操作数据表的API,常用方法:

管理类

用于数据库 层面的操作

  • openDatabase:打开指定路径的数据库。
  • isOpen:判断数据库是否已打开。
  • close:关闭数据库。
  • getVersion:获取数据库的版本号。
  • setVersion:设置数据库的版本号。

事务类

  • 用于事务层面的操作 beginTransaction:开始事务。
  • setTransactionSuccessful:设置事务的成功标志。
  • endTransaction:结束事务。

数据处理类

用于数据表层面的操作

  • execSQL:执行拼接好的SQL控制语句。
  • delete:删除符合条件的记录。
  • update:更新符合条件的记录。
  • insert:插入一条记录。
  • query:执行查询操作,返回结果集的游标。
  • rawQuery:执行拼接好的SQL查询语句,返回结果集的游标。

例:创建、删除数据库

XML文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        <Button
            android:id="@+id/btn_database_create"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="创建数据库"
            android:textSize="17sp"/>
        <Button
            android:id="@+id/btn_database_delete"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="删除数据库"
            android:textSize="17sp"/>
    </LinearLayout>
    <TextView
        android:id="@+id/tv_database"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="17sp"/>
</LinearLayout>

java代码

public class DatabaseActivity extends AppCompatActivity implements View.OnClickListener {
    private TextView tv_database;
    private String mDatabaseName;
    private String desc;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_database);
        tv_database = findViewById(R.id.tv_database);
        findViewById(R.id.btn_database_create).setOnClickListener(this);
        findViewById(R.id.btn_database_delete).setOnClickListener(this);
//        生成一个测试数据库的完整路径
        mDatabaseName = getFilesDir() + "/test.db";
    }
    @Override
    public void onClick(View view) {
        switch (view.getId()){
//            创建或打开数据库,数据库如果不存在则创建
            case R.id.btn_database_create:
               SQLiteDatabase db = openOrCreateDatabase(mDatabaseName, Context.MODE_PRIVATE,null);
                desc = String.format("数据库%s创建%s",db.getPath(),(db != null) ? "成功":"失败");
                tv_database.setText(desc);
                break;
            case R.id.btn_database_delete:
                //删除数据库
                boolean result = deleteDatabase(mDatabaseName);
                desc = String.format("数据库%s删除%s",mDatabaseName,result? "成功":"失败");
                tv_database.setText(desc);
                break;
        }
    }
}

四、数据库帮助器SQLiteOpenHelper

SQLiteOpenHelper是Android提供的数据库辅助工具,用于指导开发者进行SQLite的合理使用。

使用步骤:

  • 新建继承SQLiteOpenHelper的数据库操作类,提示重写onCreate和onUpgrade两个方法。
  • 封装保证数据库安全的必要方法。
  • 提供对表记录进行增加、删除、修改、查询的操作方法。

例:添加到数据库中

创建database包,包下创建java类

public class UserDBHelper extends SQLiteOpenHelper {
    private static final String DB_NAME = "user.db";
    private static final String TABLE_NAME = "user_info";
    private static final int DB_VERSION = 1;
    private static UserDBHelper mHelper = null;
    private SQLiteDatabase mRDB = null;
    private SQLiteDatabase mWDB = null;
    private UserDBHelper(Context context){
        super(context,DB_NAME,null,DB_VERSION);
    }
//    利用单例模式获取数据库帮助器的唯一实例
    public static UserDBHelper getInstance(Context context){
        if(mHelper == null){
            mHelper = new UserDBHelper(context);
        }
        return mHelper;
    }
//    打开数据库的读连接
    public SQLiteDatabase openReadLink(){
        if(mRDB == null || !mRDB.isOpen()){
            mRDB = mHelper.getReadableDatabase();
        }
        return mRDB;
    }
//    打开写连接
    public SQLiteDatabase openWriteLink(){
        if(mWDB == null || !mWDB.isOpen()){
            mWDB = mHelper.getWritableDatabase();
        }
        return mWDB;
    }
//    关闭数据库连接
    public void closeLink(){
        if(mRDB != null && mRDB.isOpen()){
            mRDB.close();
            mRDB = null;
        }
        if(mWDB != null && mWDB.isOpen()){
            mWDB.close();
            mWDB = null;
        }
    }
//    创建数据库,执行建表语句
    @Override
    public void onCreate(SQLiteDatabase db) {
        String sql = "CREATE TABLE IF NOT EXISTS "+TABLE_NAME+"(" +
                "id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL," +
                "name VARCHAR NOT NULL);";
        db.execSQL(sql);
    }
    @Override
    public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
    }
    public long insert(User user){
        ContentValues values = new ContentValues();
        values.put("name",user.name);
        return mWDB.insert(TABLE_NAME,null,values);
    }
}

XML文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="5dp">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:orientation="horizontal">
        <TextView
            android:id="@+id/tv_name"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:gravity="center"
            android:text="姓名"
            android:textSize="17sp"/>
        <EditText
            android:id="@+id/et_name"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:hint="请输入姓名"
            android:inputType="text"
            android:textSize="17sp"/>
    </LinearLayout>
    <Button
        android:id="@+id/btn_add"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="添加"
        android:textSize="17sp"/>
</LinearLayout>

Userjava类

public class User {
    public int id;
    public String name;
    public User(){
    }
    public User(String name){
        this.name = name;
    }
}

Activity java类

public class SQLiteHelperActivity extends AppCompatActivity implements View.OnClickListener {
    private TextView et_name;
    private UserDBHelper mHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_sqlite_helper);
        et_name = findViewById(R.id.et_name);
        findViewById(R.id.btn_add).setOnClickListener(this);
    }
    @Override
    protected void onStart() {
        super.onStart();
//        打开数据库帮助器的实例
        mHelper = UserDBHelper.getInstance(this);
//        打开数据库帮助器的读写连接
        mHelper.openWriteLink();
        mHelper.openReadLink();
    }
    @Override
    protected void onStop() {
        super.onStop();
        mHelper.closeLink();
    }
    @Override
    public void onClick(View view) {
        String name = et_name.getText().toString();
        User user = null;
        switch (view.getId()){
            case R.id.btn_add:
//                以下声明一个用户信息对象,并填写它的各字段值
                user = new User(name);
                if(mHelper.insert(user)>0){
                    Toast.makeText(this,"添加成功",Toast.LENGTH_SHORT).show();
                }
                break;
        }
    }
}

到此这篇关于Android SharePreferences与数据库SQLite存储实现方法介绍的文章就介绍到这了,更多相关Android SharePreferences内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

AndroidSharePreferences与数据库SQLite存储实现方法介绍

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android如何通过SQLite数据库实现数据存储管理

这篇文章主要介绍了Android如何通过SQLite数据库实现数据存储管理,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。0 实验环境在Android Studio中进行有关代
2023-06-25

Springboot与vue实现数据导出方法具体介绍

这篇文章主要介绍了Springboot与vue实现数据导出方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2023-02-09

ReactHooks获取数据实现方法介绍

这篇文章主要介绍了reacthooks获取数据,文中给大家介绍了useStatedispatch函数如何与其使用的FunctionComponent进行绑定,实例代码给大家介绍的非常详细,需要的朋友可以参考下
2022-11-13

android studio数据存储建立SQLite数据库怎么实现增删查改

今天就跟大家聊聊有关android studio数据存储建立SQLite数据库怎么实现增删查改,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。实验目的:分别使用sqlite3工具和An
2023-06-22

JavaJDBCAPI介绍与实现数据库连接池流程

JDBC是指Java数据库连接,是一种标准Java应用编程接口(JAVAAPI),用来连接Java编程语言和广泛的数据库。从根本上来说,JDBC是一种规范,它提供了一套完整的接口,允许便携式访问到底层数据库,本篇文章我们来了解JDBCAPI及数据库连接池
2022-12-08

PHP底层的高效数据存储与实现方法

PHP底层的高效数据存储与实现方法随着互联网的发展,数据的存储和处理成为了各个应用领域的重要环节。在开发Web应用时,PHP作为一种常见的编程语言,其底层数据存储与实现方法的选择直接影响到系统的性能和稳定性。本文将介绍一些PHP底层的高效数
PHP底层的高效数据存储与实现方法
2023-11-08

C++异步数据交换实现方法介绍

这篇文章主要介绍了C++异步数据交换实现方法,异步数据交换,除了阻塞函数send()和recv()之外,Boost.MPI还支持与成员函数isend()和irecv()的异步数据交换
2022-11-21

数据库水平分割:实现数据存储与计算分离的法宝

数据库水平分割是一种将数据库中的数据分布在多个节点上的技术,它可以实现数据存储与计算的分离,提高数据库的性能和可用性。
数据库水平分割:实现数据存储与计算分离的法宝
2024-02-24

在android开发中进行数据存储与访问的多种方式介绍

数据存储与访问 很多时候我们的软件需要对处理后的数据进行存储或再次访问。Android为数据存储提供了多种方式,分别有如下几种: 文件 SharedPreferences SQLite数据库 内容提供者(Content provider)
2022-06-06

Android使用SharedPreferences存储数据的实现方法

本文实例讲述了Android使用SharedPreferences存储数据的实现方法。分享给大家供大家参考,具体如下: 编辑短信的时候,突然接收到电话,通过这种方式可以保存之前已经编辑好的短信内容@Override public void
2022-06-06

Python模块对Redis数据库的连接与使用方法介绍

这篇文章主要讲解了“Python模块对Redis数据库的连接与使用方法介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python模块对Redis数据库的连接与使用方法介绍”吧!下面看看P
2023-06-20

阿里云SQL数据库块存储的位置与实现原理

本文将详细介绍阿里云SQL数据库中块存储的位置及其实现原理,帮助读者更好地理解和使用阿里云SQL数据库。正文:阿里云SQL数据库的块存储是一种基于分布式文件系统的存储方式,它将大量的数据分成多个块存储在不同的服务器上,每个块都是一个独立的文件。这种存储方式既能够提高数据的存储效率,又能够保证数据的安全性。块存储的
阿里云SQL数据库块存储的位置与实现原理
2023-11-04

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录