Android提供了5种方式存储数据DOC.docx
- 文档编号:17004945
- 上传时间:2023-07-21
- 格式:DOCX
- 页数:20
- 大小:24.44KB
Android提供了5种方式存储数据DOC.docx
《Android提供了5种方式存储数据DOC.docx》由会员分享,可在线阅读,更多相关《Android提供了5种方式存储数据DOC.docx(20页珍藏版)》请在冰点文库上搜索。
Android提供了5种方式存储数据DOC
Android提供了5种方式存储数据
--使用SharedPreferences存储数据;
--文件存储数据;
--SQLite数据库存储数据;
--使用ContentProvider存储数据;
--网络存储数据
一:
使用SharedPreferences存储数据
首先说明SharedPreferences存储方式,它是Android提供的用来存储一些简单配置信息的一种机制,
例如:
登录用户的用户名与密码。
其采用了Map数据结构来存储数据,以键值的方式存储,可以简单的读取与写入,具体实例如下:
voidReadSharedPreferences(){
StringstrName,strPassword;
SharedPreferencesuser=getSharedPreferences(“user_info”,0);
strName=user.getString(“NAME”,””);
strPassword=usergetString(“PASSWORD”,””);
}
voidWriteSharedPreferences(StringstrName,StringstrPassword){
SharedPreferencesuser=getSharedPreferences(“user_info”,0);
uer.edit();
user.putString(“NAME”,strName);
user.putString(“PASSWORD”,strPassword);
mit();
}
数据读取与写入的方法都非常简单,只是在写入的时候有些区别:
先调用edit()使其处于编辑状态,然后才能修改数据,最后使用commit()提交修改的数据。
实际上SharedPreferences是采用了XML格式将数据存储到设备中,在DDMS中的FileExplorer中的/data/data/
以上面的数据存储结果为例,打开后可以看到一个user_info.xml的文件,打开后可以看到:
xmlversion=”1.0″encoding=”UTF-8″?
>
使用SharedPreferences是有些限制的:
只能在同一个包内使用,不能在不同的包之间使用。
使用步骤:
存数据:
使用SharedPreferences保存数据要经过4个步骤:
获取对象、创建编辑器、修改内容、提交修改。
接下来就仔细查看这四个步骤究竟是怎样的一个过程:
1.获取对象
通过getSharedPreferences()方法获取一个SharedPreferences对象,以方便对其进行相关操作,方法如下:
getSharedPreferences("Content",Context.MODE_PRIVATE);
2.创建一个Editor编辑器
在SharedPreferences中要编辑信息,必须取得一个编辑器,也就是Editor。
Editor对象的作用是提供一些方法以便使用者修改XML文件中的内容,如添加字符串或整数等。
方法如下:
SharedPreferences.edit();
3.使用Editor修改内容
SharedPreferences根据方法名创建一个
方法如下:
putString("String",data);
4.提交内容
将数据修改好之后,也就是putString()或其他put()方法执行完后,要将这个修改提交给SharedPreferences,以通知其将内容写入到XML文件中。
使用的方法如下:
mit();
读数据:
只要两个步骤就可以顺利取出保存的数据并使用:
1.获得SharedPreferences对象
获得的方法如下:
getSharedPreferences("Content",Context.MODE_PRIVATE);
2.取出Key对应的Value即内容
我们只要使用getString()等方法就可以了:
SharedPreferences.getString()
SharedPreferences.getBoolean()
SharedPreferences.getFloat()
SharedPreferences.getInt()
SharedPreferences.getLong()
二:
文件存储数据
文件存储方式是一种较常用的方法,在Android中读取/写入文件的方法,与Java中实现I/O的程序是完全一样的,提供了openFileInput()和openFileOutput()方法来读取设备上的文件。
FilterInputStream,FilterOutputStream等可以到Javaiopackage说明中去详细学习,不再此详细说明,具体实例如下:
Stringfn=“moandroid.log”;
FileInputStreamfis=openFileInput(fn);
FileOutputStreamfos=openFileOutput(fn,Context.MODE_PRIVATE);
除此之外,Android还提供了其他函数来操作文件,详细说明请阅读androidsdk。
1.文件保存在哪里
事实上,文件保存的路径与SharedPreferences的保存路径差不多,位于/data/data/
2.文件操作的一些方法
知道文件保存的位置和形式后,接下来需要知道操作文件的一些重要的方法,如表所示:
操作文件的重要方法含义
openFileInput()打开应用程序文件以便读取
openFileOutput()创建应用程序文件以便写入
deleteFile()通过名称删除文件
fileList()获得所有位于/data/data/
getFileDir()获得/data/data/
getCacheDir()获得/data/data/
getDir()根据名称创建或获取一个子目录
在程序默认位置创建和写入文件
我们知道在Java中通过使用流来读写文件,要创建一个文件首先要建立一个输出流。
在Android中同样如此,我们依靠openFileOutput()来获得一个输出流。
它将在上一节中展示的位置创建一个文件,使用一个流要3个步骤:
1.获得一个输出流对象
获得一个输出流对象以进行文件操作,使用openFileOutput()方法可以很方便的获得,如下所示:
openFileOutput(“myFile.txt”,Context.MODE_PRIVATE);
2.向流中写入数据
获得了输出流之后我们需要向流中添加我们需要添加的信息了,同样非常方便,使用write()方法就可以了:
write(data.getBytes());
3.关闭流
当数据写入完毕后,使用close()方法可以关闭输出流,方法如下所示:
fos.close();
在默认位置读取文件
与上面类似,Android提供了读取文件的简便方法,同样需要3个步骤:
1.创建输入流
首先,得到了一个输入字节流,参数是文件名。
fis=openFileInput(“myFile”);
接着,将其转换为字符流,这样可以一个字符一个字符地读取以便显示中文。
isr=newInputStreamReader(fis);
br=newBufferedReader(isr);
最后,我们又将其包装为缓冲流,这样可以一段一段地读取,减少读写的次数,保护硬盘。
2.读取数据
从流中获得数据同样非常方便,这里没有使用read()方法而使用了readLine()方法,原因下文也会给出,代码如下:
Strings=null;
S=(br.readLine());
3.关闭输入流
这里记得每个流都要关闭哦:
fis.close();
isr.close();
br.close();
三.SQLite数据库
本节将讲解使用Android自带的关系型数据库——SQLite。
它是一个基于文件的轻量级数据库,为嵌入式设备量身打造而成。
每个应用程序创建的数据库都是私有的,但是ContentProvider可以把数据共享给其他的应用程序。
本节中读者将学习到创建和删除数据库,创建和删除表,以及插入记录、更新记录、删除记录和查询记录等操作。
1.怎样创建数据库
创建数据库有多种方法,最简单的无疑是使用Context的openOrCreateDatabase()方法了。
当然还有更加强大的方法,比如通过SQLiteOpenHelper类更有效地管理它。
使用openOrCreateDatabase()方法创建数据库语法格式如下:
ContextWrapper.openOrCreateDatabase(Stringname,intmode,CursorFactoryfactory)
2.数据库文件被保存在哪里
事实上,与SharedPreferences类似,数据库文件被保存在如下的目录下:
/data/data/packagename/databases
3.设置数据库
创建完数据库后,为了更安全而有效地使用它,我们还需要对它进行一定的配置,主要的方法有3个,分别是:
(1)设置本地化:
db.setLocale(Locale.getDefault());
(2)设置线程安全锁:
db.setLockingEnabled(true);
(3)设置版本:
db.setVersion
(1);
4.关闭数据库
当我们不再需要使用数据库时可以考虑将其关闭,关闭的方法非常简单,只需要调用方法:
db.close();
5.删除数据库
有些时候基于某种需求我们需要将数据库彻底删除,方法同样非常简单:
Context.deleteDatabase();
创建和删除表
1.创建表
创建了数据库之后,我们接下来的工作就是在数据库中创建表了,只有拥有了表,数据库才有意义。
创建表的方法是执行相应的SQL语句。
例如,要创建一个名为userInfo_brief的表,需要的SQL语句为:
CREATETABLEuserInfo_brief(
idINTEGERPRIMARYKEYAUTOINCREMENT,
nameTEXT,
passwordTEXT);
创建person表
db.execSQL("CREATETABLEperson(_idINTEGERPRIMARYKEYAUTOINCREMENT,nameVARCHAR,ageSMALLINT)");
2.删除表
相应的,如果要删除表userInfo_brief,其SQL语句为:
DROPTABLEuserInfo_brief;
与其对应的Java代码为:
Sringsql=“DROPTABLE”+TABLENAME_1+“;”;
db.execSQL(sql)
操作记录
操作记录大致为插入操作、更新操作以及删除操作。
SQLiteDatabase类提供了3个简单的方法来完成对应的操作,它们分别是:
SQLiteDatabase.insert()
SQLiteDatabase.update()
SQLiteDatabase.delete()
1.插入记录
插入记录时,我们需要使用方法:
SQLiteDatabase.insert(Stringtable,StringnullColumnHack,ContentValuesvalues)
//ContentValues以键值对的形式存放数据
ContentValuescv=newContentValues();
cv.put("name",person.name);
cv.put("age",person.age);
//插入ContentValues中的数据
db.insert("person",null,cv);
2.更新记录
更新记录时,我们需要使用方法:
SQLiteDatabase.update(Stringtable,ContentValuesvalues,StringwhereClause,String[]whereArgs)
3.删除记录
删除记录时,我们需要使用方法:
SQLiteDatabase.delete(Stringtable,StringwhereClause,String[]whereArgs)
1.使用query()查询方法
查询数据:
Cursorc=db.rawQuery("SELECT*FROMpersonWHEREage>=?
",newString[]{"33"});
while(c.moveToNext()){
int_id=c.getInt(c.getColumnIndex("_id"));
Stringname=c.getString(c.getColumnIndex("name"));
intage=c.getInt(c.getColumnIndex("age"));
}
c.close();
//删除数据
db.delete("person","age
",newString[]{"35"});
//关闭当前数据库
db.close();
//删除test.db数据库
//deleteDatabase("test.db");
}
SQLite数据库提供了一些方法可以使我们很方便的执行查询,而避免了写一些繁琐的SELECT查询语句,当然,你也不必担心,因为它提供的方法其实与SELECT语句一脉相承。
其语法格式如下:
SQLiteDatabase.query(Stringtable,String[]columns,Stringselection,String[]selectionArgs,StringgroupBy,Stringhaving,StringorderBy)
2.使用Cursor对象保存查询结果
Cursor对象只能暂时地保存数据,如果只需要完成一些简单的操作可以快速地执行,执行完后关闭它。
接下来学习一些经常使用的Cursor对象的方法;
(1)Cursor.getCount()获得Cursor对象中记录条数,可以理解为有几行。
(2)Cursor.getColumnCount(),获得Cursor对象中记录的属性个数,可以理解为有几列。
(3)Cursor.moveToFirst(),将Cursor对象的指针指向第一条记录。
(4)Cursor.moveToNext(),将Cursor对象的指针指向吓一跳。
(5)Cursor.isAfterLast(),判断Cursor对象的指针是否指向最后一条记录。
(6)Cursor.close(),关闭Cursor对象。
(7)Cursor.deactivate(),取消激活状态。
(8)Cursor.requery(),重新查询刷新数据。
3.执行查询操作
4.使用SQLiteQueryBuilder
如果我们需要执行多表查询就要使用SQLiteQueryBuilder,接下来我们需要执行多表查询:
SELECTuser_brief.name,
User_brief.password,
User_detail.age,
User_detail.sex
FROMuser_brief,user_detail
WHEREuser_brief.name=user_detail.nameANDuser_brief.name=“wes”
ORDERBYageASC
为了能更好地管理数据库,AndroidSDK为我们提供了数据库的一个帮助类——SQLiteOpenHelper。
要使用SQLiteOpenHelper类需要如下步骤:
1.继承SQLiteOpenHelper类
2.得到帮助类的对象
通过帮助类的构造方法可以顺利地得到帮助类的对象:
DatabaseHelperhelper=newDatabaseHelper(Contextcontext,Stringname,CursorFactoryfactory,intversion)
3.获得数据库
顺利地获得数据库帮助类的对象后,无论在什么时候,我们都可以很方便地得到一个可读或者可写数据库,得到可写数据库的具体语法格式如下:
SQLiteOpenHelper.getWritableDatabase()
或者可以通过以下方法得到可读数据库:
SQLiteOpenHelper.getReadableDatabase()
事务的操作
publicvoidadd(List
db.beginTransaction();//开始事务
try{
for(Personperson:
persons){
db.execSQL("INSERTINTOpersonVALUES(null,?
?
?
)",newObject[]{person.name,person.age,person.info});
}
db.setTransactionSuccessful();//设置事务成功完成
}finally{
db.endTransaction();//结束事务
}
}
四:
ContentProvider
1、ContentProvider简介
当应用继承ContentProvider类,并重写该类用于提供数据和存储数据的方法,就可以向其他应用共享其数据。
虽然使用其他方法也可以对外共享数据,但数据访问方式会因数据存储的方式而不同,如:
采用文件方式对外共享数据,需要进行文件操作读写数据;采用sharedpreferences共享数据,需要使用sharedpreferencesAPI读写数据。
而使用ContentProvider共享数据的好处是统一了数据访问方式。
2、Uri类简介
Uri代表了要操作的数据,Uri主要包含了两部分信息:
1.需要操作的ContentProvider,2.对ContentProvider中的什么数据进行操作,一个Uri由以下几部分组成:
1.scheme:
ContentProvider(内容提供者)的scheme已经由Android所规定为:
content:
//。
2.主机名(或Authority):
用于唯一标识这个ContentProvider,外部调用者可以根据这个标识来找到它。
3.路径(path):
可以用来表示我们要操作的数据,路径的构建应根据业务而定,如下:
要操作contact表中id为10的记录,可以构建这样的路径:
/contact/10
要操作contact表中id为10的记录的name字段,contact/10/name
要操作contact表中的所有记录,可以构建这样的路径:
/contact?
要操作的数据不一定来自数据库,也可以是文件等其他存储方式,如下:
要操作xml文件中contact节点下的name节点,可以构建这样的路径:
/contact/name
如果要把一个字符串转换成Uri,可以使用Uri类中的parse()方法,如下:
Uriuri=Uri.parse("content:
//com.changcheng.provider.contactprovider/contact")
3、UriMatcher、ContentUrist和ContentResolver简介
因为Uri代表了要操作的数据,所以我们很经常需要解析Uri,并从Uri中获取数据。
Android系统提供了两个用于操作Uri的工具类,分别为UriMatcher和ContentUris。
掌握它们的使用,会便于我们的开发工作。
UriMatcher:
用于匹配Uri,它的用法如下:
1.首先把你需要匹配Uri路径全部给注册上,如下:
//常量UriMatcher.NO_MATCH表示不匹配任何路径的返回码(-1)。
UriMatcheruriMatcher=newUriMatcher(UriMatcher.NO_MATCH);
//如果match()方法匹配content:
//com.changcheng.sqlite.provider.contactprovider/contact路径,返回匹配码为1
uriMatcher.addURI(“com.changcheng.sqlite.provider.contactprovider”,“contact”,1);//添加需要匹配uri,如果匹配就会返回匹配码
//如果match()方法匹配content:
//com.changcheng.sqlite.provider.contactprovider/contact/230路径,返回匹配码为2
uriMatcher.addURI(“com.changcheng.sqlite.provider.contactprovider”,“contact/#”,2);//#号为通配符
2.注册完需要匹配的Uri后,就可以使用uriMatcher.match(uri)方法对输入的Uri进行匹配,如果匹配就返回匹配码,匹配码是调用addURI()方法传入的第三个参数,假设匹配content:
//com.changcheng.sqlite.provider.contactprovider/contact路径,返回的匹配码为1。
ContentUris:
用于获取Uri路径后面的ID部分,它有两个比较实用的方法:
withAppendedId(uri,id)用于为路径加上ID部分
parseId(uri)方法用于从路径中获取ID部分
ContentResolver:
当外部应用需要对ContentProvider中的数据进行添加、删除、修改和查询操作时,可以使用ContentResolver类来完成,要获取ContentResolver对象,可以使用Activity提供的getContentResolver()方法。
ContentResolver使用insert、delete、update、query方法,来
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Android 提供 方式 存储 数据 DOC