|
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);
} |
|