当前位置:网站首页>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) {
}
}边栏推荐
猜你喜欢
随机推荐
WARNING: sql version 9.2, server version 11.0.Some psql features might not work.
显式调用类的构造函数(而不是用赋值构造),实现一个new操作
关系型数据库-MySQL:约束管理、索引管理、键管理语句
个人练习三剑客基础之模仿CSDN首页
ES6 Const Let Var的区别
bind和function
Delphi-C side interesting menu operation interface design
智能合约安全——私有数据访问
IvNWJVPMLt
登录页面js手写
纳米级完全删除MYSQL5.7以及一些吐槽
BUUCTF——MISC(一)
MySql--存储引擎以及索引
[原创]STL容器map和unordered_map性能,创建,插入,随机访问速度对比!
Zend FrameWork RCE1
箭头函数的使用
(十二)树--哈夫曼树
剑指 Offer 2022/7/3
自动化运维工具Ansible(2)ad-hoc
(十三)二叉排序树









