本文旨在複習總結Android持久化存儲方法,只列出了主要代碼以及少許批註,僅做爲複習參考使用。java
全部文件默認放在/data/data/<packagename>/files/
目錄下android
public void save(String inputText){ FileOutputStream out=null; BufferedWriter writer=null; try { out=openFileOutput("data", Context.MODE_PRIVATE); writer=new BufferedWriter(new OutputStreamWriter(out)); writer.write(inputText); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); }finally { if(writer!=null){ try { writer.close(); } catch (IOException e) { e.printStackTrace(); } } } }
public String load(){ FileInputStream in =null; BufferedReader reader=null; StringBuilder content=new StringBuilder(); try { in=openFileInput("data"); reader=new BufferedReader(new InputStreamReader(in)); String line=""; while ((line=reader.readLine())!=null){ content.append(line); } } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); }finally { if(reader!=null){ try { reader.close(); } catch (IOException e) { e.printStackTrace(); } } } return content.toString(); }
SharePreference
文件默認放在/data/data/<packagename>/shared_prefs/目錄下
數據庫
SharedPreferences.Editor editor=getSharedPreferences("data",MODE_PRIVATE).edit(); editor.putString("et_inputText","sharePreferences test"); editor.commit();
SharedPreferences sp=getSharedPreferences("data",MODE_PRIVATE); String input=sp.getString("et_inputText","請輸入用戶名");//第二個參數是爲空的默認信息
SQLite
文件默認放在/data/data/<packagename>/databases/目錄下
app
public class MyDataBaseHelper extends SQLiteOpenHelper{ private static final String CREATE_BOOK="create table Book(" +"id integer primary key autoincrement, " +"author text, " +"price real, " +"pages integer, " +"name text)"; private static final String CREATE_CATEGORY="create table Category(" +"id integer primary key autoincrement, " +"category_name text, " +"category_code integer)"; private Context mContext; public MyDataBaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) { super(context, name, factory, version); mContext=context; } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(CREATE_BOOK); db.execSQL(CREATE_CATEGORY); Toast.makeText(mContext,"create succeed",Toast.LENGTH_SHORT).show(); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL("drop table if exists Book"); db.execSQL("drop table if exists Category"); onCreate(db); }
建立數據庫ide
dbHelper=new MyDataBaseHelper(this,"BookStore.db",null,2);
插入數據ui
SQLiteDatabase db=dbHelper.getWritableDatabase(); ContentValues values=new ContentValues(); values.put("name","Effective Java"); values.put("author","Joshua Bloch"); values.put("pages",454); values.put("price",16.96); db.insert("Book",null,values);
更新數據this
ContentValues values=new ContentValues(); values.put("price",198.00); SQLiteDatabase db=dbHelper.getReadableDatabase(); db.update("Book",values,"name=?",new String[]{"Android Programme"});
刪除行code
SQLiteDatabase db = dbHelper.getWritableDatabase(); db.delete("Book", "pages > ?", new String[] { "500" });
ContentValues
知識android提供的一個便於數據庫操做的類,爲數據庫操做提供便利,也能夠直接使用數據庫語句進行操做rem
參考書目《第一行代碼》get
個人文章列表Email:sxh13208803520@gmail.com