赞
踩
android的五种数据存储方式
一、文件存储
默认存储路径:
/data/data/<PackageName>/files文件操作模式:
MODE_PRIVATE(默认):覆盖、MODE_APPEND:追加
- public void save(){
- String data = "save something here";
- FileOutputStream out = null;
- ButteredWriter writer = null;
- try{
- out = openFileOutput("data",Context.MODE_PRIVATE);
- writer = new ButteredWriter(new OutputSreamWriter(out));
- writer.write(data);
- }catch(IOException e){
- e.printStackTrace();
- }finally{
- try{
- if(writer!=null){
- writer.close();
- }
- }catch(IOException e){
- e.printStackTrace();
- }
- }
- public String load(){
- FileInputStream in = null;
- ButteredReader reader = null;
- StringBuilder builder = new StringBuilder();
- try{
- in = openFileInput("data");
- reader = new ButteredReader(new InputStreamReader(in));
- String line= "";
- while((line = reader.readline()) != null){
- builder.append();
- }
- }catch(IOException e){
- e.printStackTrace();
- }finally{
- if(reader != null){
- try{
- reader.close();
- }catch(IOException e){
- e.printStackTrace();
- }
- }
- }
- }
二、SharedPreferences
默认存储路径:
/data/data/<PackageName>/shared_prefs操作模式:
MODE_PRIVATE(默认):只有当前的应用程序才能对文件进行读写、MODE_MULTI_PROCESS:用于多个进程对同一个SharedPreferences进行读写。存储数据格式:
键值对
获取SharedPreferences对象的方法
存储数据
- SharedPreferences.Editor editor = getSharedPreferences("data",MODE_PRIVATE).edit();
- editor.putString("name","ZhangSan");
- editor.putInt("age",12);
- editor.putBoolean("isMarried",false);
- editor.commit();
从SharedPreferences文件中读取数据
- SharedPreferences pref = getSharedPreferences("data",MODE_PRIVATE);
- String name = pref.getString("name");
- int age = pref.getInt("age");
- boolean isMarried = pref.getBoolean("isMarried");
三、SQLite数据库存储
默认存储路径:
/data/data/<PackageName>/databases数据类型
- public class MyDatabaseHelper extends SQLiteOpenHelper{
- public static final String CREATE_BOOK = "create table book ( "
- + " id integer primary key autoincrement,"
- + " author text,"
- + "price real,"
- + "pages integer,"
- + "name text)";
- private Context context;
- public MyDatabaseHelper (Context context, String name, CursorFactory factory, int version) {
- super(context, name, factory, version);
- this.context = context;
- }
-
- @Override
- public void onCreate(SQLiteDatabase db) {
- db.execSQL(CREATE_BOOK);
- }
-
- //当打开数据库时传入的版本号与当前的版本号不同时会调用该方法
- @Override
- public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
-
- }
- }
在MainActivity中
- MyDatabaseHelper helper = new MyDatabaseHelper(this,"BookStore.db",null,1);
- //检测到没有BookStore这个数据库,会创建该数据库并调用MyDatabaseHelper中的onCreated方法。
- helper.getWritableDatabase();
升级数据库
- public class MyDatabaseHelper extends SQLiteOpenHelper{
- ......
- //当打开数据库时传入的版本号与当前的版本号不同时会调用该方法
- @Override
- public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
- db.execSQL("drop table if exists Book");
- onCreate(db):
- }
- }
在MainActivity中只需将version改为大于原来版本号即可。
- MyDatabaseHelper helper = new MyDatabaseHelper(this,"BookStore.db",null,2);
- helper.getWritableDatabase();
向数据库添加数据
insert()方法,参数一表名,参数二是在未指定添加数据的情况下给某些可为空的列自动赋值为NULL,设置为null即可,参数三是ContentValues对象。MainActivity
- SQLiteDatabase db = helper.getWritableDatabase();
- ContentValues values = new ContentValues();
- values.put("name","The Book Name");
- values.put("author","chen");
- values.put("pages",100);
- values.put("price",200);
- db.insert("Book",null,values);
更新数据库中的数据
update()方法,参数一是表名,参数二是ContentValues对象,参数三、四是去约束更新某一行或某几行的数据,不指定默认更新所有。MainActivity
- SQLiteDatabase db = helper.getWritableDatabase();
- ContentValues values = new ContentValues();
- values.put("price",120);
- db.update("Book",values,"name= ?",new String[]{"The Book Name"});
从数据库中删除数据
delete()方法,参数一是表名,参数二、三是去约束删除某一行或某几行的数据,不指定默认删除所有。MainActivity
- SQLiteDatabase db = helper.getWritableDatabase();
- db.delete("Book","pages> ?",new String[]{"100"});
查询数据库中的数据
query()方法,参数一是表名,参数二是指定查询哪几列,默认全部,参数三、四是去约束查询某一行或某几行的数据,不指定默认查询所有,参数五是用于指定需要去group by的列,参数六是对group by的数据进一步的过滤,参数七是查询结果的排序方式MainActivity
- SQLiteDatabase db = helper.getWritableDatabase();
- Cursor cursor = db.query("Book",null,null,null,null,null,null);
- if(cursor.moveToFirst()){
- do{
- String name = cursor.getString(cursor.getColumnIndex("name");
- String author = cursor.getString(cursor.getColumnIndex("author");
- int pages = cursor.getString(cursor.getColumnIndex("pages");
- double price = cursor.getString(cursor.getColumnIndex("price");
- }while(cursor.moveToNext());
- }
- cursor.close():
使用SQL语句操作数据库
- //添加数据
- db.execSQL("insert into Book(name,author,pages,price) values(?,?,?,?) "
- ,new String[]{"The Book Name","chen",100,20});
- //更新数据
- db.execSQL("update Book set price = ? where name = ?",new String[]
- {"10","The Book Name"});
- //删除数据
- db.execSQL("delete from Book where pages > ?",new String[]{"100"});
- //查询数据
- db.execSQL("select * from Book",null);
使用事务操作
- SQLiteDatabase db = helper.getWritableDatabase();
- db.beginTransaction(); //开启事务
- try{
- ......
- db.insert("Book",null,values);
- db.setTransactionSuccessful(); //事务成功执行
- }catch(SQLException e){
- e.printStackTrace();
- }finally{
- db.endTransaction(); //结束事务
- }
四、ContentProvider
ContentProvider主要用于不同的程序之间实现数据共享的功能。
工具类ContentResolver
,提供了一系列方法对数据进行CRUD操作。
ContentResolver的使用方法
1、内容URI
内容URI是由权限和路径组成的,权限是用于区分不同的应用程序,一般是以包名来命名。路径是用于区分同一个应用程序的不同表。
- //包名为com.example.app的表table1访问路径
- Uri uri = Uri.parse("content://com.example.app.provider/table1");
2、使用Uri对象进行数据操作
- Cursor cursor = getContentResolver().query(uri,null,null,null,null);
- if(cursor != null){
- while(cursor.moveToNext()){
- String column1 = cursor.getString(cursor.getColumnIndex("column1"));
- String column2 = cursor.getString(cursor.getColumnIndex("column2"));
- }
- cursor.close();
- }
- ContentValues values = new ContentValues();
- values.put("column1","text");
- values.put("column2",1);
- getContentResolver().insert(uri,values);
五、网络存储
作者:cy_why
链接:https://www.jianshu.com/p/536ca489a7f4
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。