当前位置:网站首页>android基础 [超级详细android存储方式解析(SharedPreferences,SQLite数据库存储)]
android基础 [超级详细android存储方式解析(SharedPreferences,SQLite数据库存储)]
2022-08-04 05:28:00 【手下留键盘】
目录
1.Android存储方式
1.1Android共有5中存储方式:
SharedPreferences
内部存储(Internal Storage)
外部存储(External Storage)
SQLite数据库存储
网络存储(现阶段主流)
今天我们主要讲解SharedPreferences(文件存储)和SQLite数据库存储。
2.SharedPreferences(文件存储)
2.1简介
文件,相当于properties文件,数据存储都是使用键值对来存储。
2.2写入
a.获取SharedPreferences(①:getSharedPrefernces,②:getPrefernces)
①和②获取方式的区别是前者两个参数(存储文件名称和操作模式(int mode)),后者只有操作模式一个参数。
b.借助Editor,向SharedPreferenxce中写入数据。
c.写入数据,只能写入原始基本数据(boolean,float,int,long,String),不能写复合型数据。
d.提交数据。
调用 SharedPreferences.Editor 的 commit() 方法将更新提交到 SharedPreferences 中。
String name="zs";
String pwd="123";
SharedPreferences sp= getSharedPreferences("logininfo",MODE_PRIVATE);
SharedPreferences.Editor edit = sp.edit();
edit.putString("name",name);
edit.putString("pwd",pwd);
edit.commit();
2.3读取
a.获取sharedPrefernces。
b.获取数据。
SharedPreferences sp1= getSharedPreferences("logininfo",MODE_PRIVATE);
String sp_name = sp1.getString("name", "");
String sp_pwd = sp1.getString("pwd", "");
3.SQLite数据库存储
3.1简介
特点:轻量,无需配置。
缺点:本地化。
3.2创建
a.用Class,DBHelper 继承SQLiteOpenHelper。
public class DBHelper extends SQLiteOpenHelper {
}
b.实现两个抽象方法 onCreate() onUpgrade() 创建一个带参的构造方法。
public class DBHelper extends SQLiteOpenHelper {
public DBHelper(@Nullable Context context) {
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
}
}
c.在构造方法中 创建数据库。
public class DBHelper extends SQLiteOpenHelper {
public DBHelper(@Nullable Context context) {
super(context, "school.db", null, 1);
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
}
}
d.在onCreate() 方法中,创建表和插入数据。
public class DBHelper extends SQLiteOpenHelper {
public DBHelper(@Nullable Context context) {
super(context, "school.db", null, 1);
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
sqLiteDatabase.execSQL("create table student(sid integer primary key,sname text,sex text)");
sqLiteDatabase.execSQL("insert into student values(1,'zs','男')");
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
}
}
边栏推荐
猜你喜欢
随机推荐
对象存储-分布式文件系统-MinIO-2:服务端部署
实际开发中左菜单自定义图标点击切换
数据库根据提纲复习
lmxcms1.4
二月、三月校招面试复盘总结(二)
flink自定义轮询分区产生的问题
组原模拟题
跨域问题的解决
ES6 Const Let Var的区别
Kubernetes基本入门-集群资源(二)
SQL练习 2022/7/5
(六)递归
Programming hodgepodge (3)
自动化运维工具Ansible(1)基础
VScode配置PHP环境
Set集合与Map集合
pgsql函数中的return类型
Vulnhub:Sar-1
对象存储-分布式文件系统-MinIO-3:MinIo Client(mc)
JS深复制对象方法(深拷贝)