Android基础之数据存储SharedPreference和SQLite

本文介绍了Android应用中两种常见的数据存储方式:SharedPreferences用于保存简单的键值对数据,如用户配置;SQLite数据库则适用于存储较为复杂的数据结构,通过示例展示了如何进行增删改查等基本操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SharedPreference

对小规模数据存储非常方便,主要存储一些键值对
一般用来存储用户对应用程序的配置,下面演示了用SharedPreference记录用户设置有无声音的配置
public class Calc extends Activity{
public static final String PREFERS_NAME="MyPrefersFile";
public void onCreate(){
//创建的时候查看SharedPreference中的配置
//获得SharedPreference对象
SharedPreferences settings=getSharedPreferences(PREFERS_NAME,0); //0表示默认状态,还有只读,可写等
//当有多个SharedPreference的时候,如果只有一个,getPreferences()不用指定名字
boolean silent=settings.getBoolean("silentMode",false);
setSilent(silent);
}

public void onPause(){

//退出的时候存储silent的状态
SharedPreferences settings=getSharedPreferences(PREFERS_NAME,0);
SharedPreferences.Editor editor=settings.edit();
editor.putBoolean("silentMode",silentStatus);
editor.commit();
}
}

或者这个对用户名和密码本地记录
public class LoginActivity extends Activity{
private String username;
private String pwd;

loginButton.setOnClickListener.........{
public void onClick(){
SharedPreferences userInfo=getSharedPreferences("userInfo",0);
userInfo.edit().putString("username",username).commit();
userInfo.edit().putString("pwd",pwd).commit();
}
}
public void onCreate(){
SharedPreferences userInfo=getSharedPreferences("userInfo",0);
username=userInfo.getString("username");
pwd=userInfo.getString("pwd");
userEditText.setText(username);
pwdEditText.setText(pwd);

}


}




SQLite数据库

对SQLite数据库进行操作可以借助SQLiteOpenHelper类
public class MyDBHelper extends SQLiteOpenHelper{
//需要实现onCreate和onUpgrade方法
public void onCreate(SQLiteDatabase db){
//这个是在openHelper创建的时候执行的语句,这时候要创建一个表对象
db.exec("create table users(.....)");
}
public void onUpgrade(){

}
}

使用的时候:
//首先生成一个OpenHelper子类的对象
MyDBHelper helper=new MyDBHelper(LoginActivity.this,"newDataBase",null,1); //参数一次为上下文,数据库的名字
//获得一个SQLite数据库对象
SQLiteDatabase db=helper.getWritableDatabase();
//使用得到的数据库对象db对数据库进行操作
ContentValues values=new ContentValues();
values.put("id",1);
values.put("name","Vincent");
//插入操作
db.insert("user",null,values); //参数依次是表名,null,键值对
//更新
db.update("user",values,"id=?",new int[]{1,2,3}); //参数依次是表名,键值,WHERE语句,WHERE语句对应的值
//删除
db.delete("user","id=?",new intp[]{1,2,3}); //参数依次为表名,WHERE语句,WHERE语句对应的值
//查询
Cursor cur=db.query("user", new String[]{"id","name"}, "id=?", new String[]{"1"}, null, null, null);

表名 选中的列 WHERE语句 条件域 groupBy having orderBy

while(cur.moveToNext()){
String name=cur.getString(cur.getColumnIndex("name"));
Log.i("nameFromDB",name);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值