android资源存储方式,Android五种数据存储方式

android的五种数据存储方式

文件存储

SharedPreferences

SQLite数据库存储

ContentProvider

网络存储

一、文件存储

默认存储路径:/data/data//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//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//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);

五、网络存储

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值