设为首页 收藏本站
查看: 1015|回复: 0

[经验分享] Android基础之数据存储SharedPreference和SQLite

[复制链接]

尚未签到

发表于 2016-12-1 08:00:42 | 显示全部楼层 |阅读模式
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、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-307858-1-1.html 上篇帖子: Android简单的SQLite操作及ListView展示数据 下篇帖子: Android开发学习笔记:数据存取之SQLite浅析
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表