当前位置:   article > 正文

Android五种数据存储方式_android数据存储的说法

android数据存储的说法

android的五种数据存储方式

  • 文件存储
  • SharedPreferences
  • SQLite数据库存储
  • ContentProvider
  • 网络存储

一、文件存储

默认存储路径:/data/data/<PackageName>/files
文件操作模式:MODE_PRIVATE(默认):覆盖、MODE_APPEND:追加

  • 写入文件

  1. public void save(){
  2. String data = "save something here";
  3. FileOutputStream out = null;
  4. ButteredWriter writer = null;
  5. try{
  6. out = openFileOutput("data",Context.MODE_PRIVATE);
  7. writer = new ButteredWriter(new OutputSreamWriter(out));
  8. writer.write(data);
  9. }catch(IOException e){
  10. e.printStackTrace();
  11. }finally{
  12. try{
  13. if(writer!=null){
  14. writer.close();
  15. }
  16. }catch(IOException e){
  17. e.printStackTrace();
  18. }
  19. }
  • 读取数据

  1. public String load(){
  2. FileInputStream in = null;
  3. ButteredReader reader = null;
  4. StringBuilder builder = new StringBuilder();
  5. try{
  6. in = openFileInput("data");
  7. reader = new ButteredReader(new InputStreamReader(in));
  8. String line= "";
  9. while((line = reader.readline()) != null){
  10. builder.append();
  11. }
  12. }catch(IOException e){
  13. e.printStackTrace();
  14. }finally{
  15. if(reader != null){
  16. try{
  17. reader.close();
  18. }catch(IOException e){
  19. e.printStackTrace();
  20. }
  21. }
  22. }
  23. }

二、SharedPreferences

默认存储路径:/data/data/<PackageName>/shared_prefs
操作模式:MODE_PRIVATE(默认):只有当前的应用程序才能对文件进行读写、MODE_MULTI_PROCESS:用于多个进程对同一个SharedPreferences进行读写。
存储数据格式:键值对

获取SharedPreferences对象的方法

  • Context的getSharedPreferences()方法,参数一是文件名,参数二是操作模式
  • Activity的getPreferences()方法,参数为操作模式,使用当前应用程序包名为文件名
  • PreferenceManager的getDefaultSharedPreferences()静态方法,接收Context参数,使用当前应用程序包名为文件名

存储数据

  • 调用SharedPreferences对象的edit()方法获取一个SharedPreferences.Editor对象
  • 向Editor对象中添加数据putBoolean、putString等
  • 调用commit()方法提交数据

  1. SharedPreferences.Editor editor = getSharedPreferences("data",MODE_PRIVATE).edit();
  2. editor.putString("name","ZhangSan");
  3. editor.putInt("age",12);
  4. editor.putBoolean("isMarried",false);
  5. editor.commit();

从SharedPreferences文件中读取数据

  1. SharedPreferences pref = getSharedPreferences("data",MODE_PRIVATE);
  2. String name = pref.getString("name");
  3. int age = pref.getInt("age");
  4. boolean isMarried = pref.getBoolean("isMarried");

三、SQLite数据库存储

默认存储路径:/data/data/<PackageName>/databases
数据类型

  • integer 整型
  • real 浮点型
  • text 文本类型
  • blob 二进制类型

  1. public class MyDatabaseHelper extends SQLiteOpenHelper{
  2. public static final String CREATE_BOOK = "create table book ( "
  3. + " id integer primary key autoincrement,"
  4. + " author text,"
  5. + "price real,"
  6. + "pages integer,"
  7. + "name text)";
  8. private Context context;
  9. public MyDatabaseHelper (Context context, String name, CursorFactory factory, int version) {
  10. super(context, name, factory, version);
  11. this.context = context;
  12. }
  13. @Override
  14. public void onCreate(SQLiteDatabase db) {
  15. db.execSQL(CREATE_BOOK);
  16. }
  17. //当打开数据库时传入的版本号与当前的版本号不同时会调用该方法
  18. @Override
  19. public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
  20. }
  21. }

在MainActivity中

  1. MyDatabaseHelper helper = new MyDatabaseHelper(this,"BookStore.db",null,1);
  2. //检测到没有BookStore这个数据库,会创建该数据库并调用MyDatabaseHelper中的onCreated方法。
  3. helper.getWritableDatabase();

升级数据库

  1. public class MyDatabaseHelper extends SQLiteOpenHelper{
  2. ......
  3. //当打开数据库时传入的版本号与当前的版本号不同时会调用该方法
  4. @Override
  5. public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
  6. db.execSQL("drop table if exists Book");
  7. onCreate(db):
  8. }
  9. }

在MainActivity中只需将version改为大于原来版本号即可。

  1. MyDatabaseHelper helper = new MyDatabaseHelper(this,"BookStore.db",null,2);
  2. helper.getWritableDatabase();

向数据库添加数据

insert()方法,参数一表名,参数二是在未指定添加数据的情况下给某些可为空的列自动赋值为NULL,设置为null即可,参数三是ContentValues对象。
MainActivity

  1. SQLiteDatabase db = helper.getWritableDatabase();
  2. ContentValues values = new ContentValues();
  3. values.put("name","The Book Name");
  4. values.put("author","chen");
  5. values.put("pages",100);
  6. values.put("price",200);
  7. db.insert("Book",null,values);

更新数据库中的数据

update()方法,参数一是表名,参数二是ContentValues对象,参数三、四是去约束更新某一行或某几行的数据,不指定默认更新所有。
MainActivity

  1. SQLiteDatabase db = helper.getWritableDatabase();
  2. ContentValues values = new ContentValues();
  3. values.put("price",120);
  4. db.update("Book",values,"name= ?",new String[]{"The Book Name"});

从数据库中删除数据

delete()方法,参数一是表名,参数二、三是去约束删除某一行或某几行的数据,不指定默认删除所有。
MainActivity

  1. SQLiteDatabase db = helper.getWritableDatabase();
  2. db.delete("Book","pages> ?",new String[]{"100"});

查询数据库中的数据

query()方法,参数一是表名,参数二是指定查询哪几列,默认全部,参数三、四是去约束查询某一行或某几行的数据,不指定默认查询所有,参数五是用于指定需要去group by的列,参数六是对group by的数据进一步的过滤,参数七是查询结果的排序方式
MainActivity

  1. SQLiteDatabase db = helper.getWritableDatabase();
  2. Cursor cursor = db.query("Book",null,null,null,null,null,null);
  3. if(cursor.moveToFirst()){
  4. do{
  5. String name = cursor.getString(cursor.getColumnIndex("name");
  6. String author = cursor.getString(cursor.getColumnIndex("author");
  7. int pages = cursor.getString(cursor.getColumnIndex("pages");
  8. double price = cursor.getString(cursor.getColumnIndex("price");
  9. }while(cursor.moveToNext());
  10. }
  11. cursor.close():

使用SQL语句操作数据库

  1. //添加数据
  2. db.execSQL("insert into Book(name,author,pages,price) values(?,?,?,?) "
  3. ,new String[]{"The Book Name","chen",100,20});
  4. //更新数据
  5. db.execSQL("update Book set price = ? where name = ?",new String[]
  6. {"10","The Book Name"});
  7. //删除数据
  8. db.execSQL("delete from Book where pages > ?",new String[]{"100"});
  9. //查询数据
  10. db.execSQL("select * from Book",null);

使用事务操作

  1. SQLiteDatabase db = helper.getWritableDatabase();
  2. db.beginTransaction(); //开启事务
  3. try{
  4. ......
  5. db.insert("Book",null,values);
  6. db.setTransactionSuccessful(); //事务成功执行
  7. }catch(SQLException e){
  8. e.printStackTrace();
  9. }finally{
  10. db.endTransaction(); //结束事务
  11. }

四、ContentProvider

ContentProvider主要用于不同的程序之间实现数据共享的功能。

  • 访问其他应用程序中的数据

工具类ContentResolver,提供了一系列方法对数据进行CRUD操作。

ContentResolver的使用方法

1、内容URI
内容URI是由权限和路径组成的,权限是用于区分不同的应用程序,一般是以包名来命名。路径是用于区分同一个应用程序的不同表。

  1. //包名为com.example.app的表table1访问路径
  2. Uri uri = Uri.parse("content://com.example.app.provider/table1");

2、使用Uri对象进行数据操作

  • 查询

  1. Cursor cursor = getContentResolver().query(uri,null,null,null,null);
  2. if(cursor != null){
  3. while(cursor.moveToNext()){
  4. String column1 = cursor.getString(cursor.getColumnIndex("column1"));
  5. String column2 = cursor.getString(cursor.getColumnIndex("column2"));
  6. }
  7. cursor.close();
  8. }
  • 插入

  1. ContentValues values = new ContentValues();
  2. values.put("column1","text");
  3. values.put("column2",1);
  4. getContentResolver().insert(uri,values);

五、网络存储



作者:cy_why
链接:https://www.jianshu.com/p/536ca489a7f4
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/319248
推荐阅读
相关标签
  

闽ICP备14008679号