Android SharePreferences与数据库SQLite存储实现方法介绍
作者:Shewyoo 发布时间:2023-03-13 11:20:45
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;
}
}
}
来源:https://blog.csdn.net/Tir_zhang/article/details/127029669


猜你喜欢
- 我们有时用C#需要实现锁住文件的功能,该如何锁住文件呢?下面小编给大家介绍一下。首先大家需要到码云里面找到如下图所示的文件锁的项目,如下图所
- 本文实例讲述了Android自定义dialog简单实现方法。分享给大家供大家参考,具体如下:@Override protected void
- 背景分析在项目的开发中,不管是对底层的数据逻辑操作过程,还是业务逻辑的处理过程,还是控制逻辑的处理过程,都不可避免会遇到各种可预知的、不可预
- 通常在C#的实际开发过程中,会发现设置其属性ScriptErrorsSuppressed无法达到屏蔽脚本错误效果,但是可以通过下面两种方式实
- 前言:文件的上传和下载在日常开发中很是常见,那么这一功能是如何实现的呢,下面我给大家介绍一下实现条件:1、需要一个form标签,method
- 效果图白话分析:多线程:肯定是多个线程咯断点:线程停止下载的位置续传:线程从停止下载的位置上继续下载,直到完成任务为止。核心分析:断点:当前
- 事件(event),这个词儿对于初学者来说,往往总是显得有些神秘,不易弄懂。而这些东西却往往又是编程中常用且非常重要的东西。大家都知道win
- 由 CardLayout 类实现的布局管理器称为卡片布
- 文章转自公众号:Coder梁(ID:Coder_LT) 1.类常量有的时候, 我们希望能给类当中定义一些常量,可以给所有类的对象使用。比如说
- TimeSpan 结构 表示一个时间间隔。命名空间:System 程序集:mscorlib(在 mscorlib.dll 中)说
- Spring整合mybatis注解扫描是否成功IDEA spring整合mybatis会使用注解扫描的配置<context:compo
- 今天介绍一下,我在项目开发过程中,实现状态栏和虚拟按键背景颜色变化的方法,实现方式是,通过隐藏系统的状态栏和虚拟按键的背景,实现图片和背景显
- 本文实例为大家分享了java实现拼图游戏的具体代码,供大家参考,具体内容如下游戏说明:设计一款拼图游戏,要求点击图片按钮,实现图片按钮的移动
- 程序员日常工作中,发送http请求特别常见。本文以Java为例,总结发送http请求的多种方式。1. HttpURLConnection使用
- 一开始我就纳闷了,怎么调试都只是一个光溜溜的界面,右侧的工具栏都没有如图:就一个光秃秃的界面,什么都没有,这就对调试很不方便于是我就试了试各
- 本文介绍了最好的Java5种遍历HashMap数据的写法,分享给大家,也给自己留一个笔记,具体如下:通过EntrySet的迭代器遍历Iter
- spinner组件有点类型于HTML中的下拉框<Select></select>的样子,让用户每次从下拉框中选取一个
- 支持趋势线的图表类型包括二维面积图、条形图、柱形图、柱形图、股价图、xy (散点图) 和气泡图中;不能向三维、堆积、雷达图、饼图、曲面图或圆
- 假设有两个线程在并发运行,一个线程执行的代码中含有一个死循环如:while(true)....当该线程在执行while(true)中代码时,
- 前言缓存技术被认为是减轻服务器负载、降低网络拥塞、增强Web可扩展性的有效途径之一,其基本思想是利用客户访问的时间局部性(Temproral