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
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值