scuess 发表于 2016-12-1 08:00:42

Android基础之数据存储SharedPreference和SQLite

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);
    }
页: [1]
查看完整版本: Android基础之数据存储SharedPreference和SQLite