android五大基本存儲方式



  • 文件存儲

  • SharedPreferences

  • SQLite數據庫存儲

  • ContentProvider

  • 網絡存儲


一、文件存儲

默認存儲路徑:/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對象的方法


  • Context的getSharedPreferences()方法,參數一是文件名,參數二是操作模式

  • Activity的getPreferences()方法,參數為操作模式,使用當前應用程序包名為文件名

  • PreferenceManager的getDefaultSharedPreferences()靜態方法,接收Context參數,使用當前應用程序包名為文件名


存儲數據


  • 調用SharedPreferences對象的edit()方法獲取一個SharedPreferences.Editor對象

  • 向Editor對象中添加數據putBoolean、putString等

  • 調用commit()方法提交數據


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
數據類型



  • integer 整型

  • real 浮點型

  • text 文本類型

  • blob 二進制類型


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);

    五、網絡存儲


0 個評論

要回覆文章請先登錄註冊