Android 五种存储方式个人总结
一 . 文件存储
FileOutputStream out = openFileOutput("data",Context.MODE_PRIVATE);
BufferedWriter writer = new BufferedWriter(new OutputStream(out));
String s ;
writer.writer(s);
二. sharePreferences 存储 (键值对形式)
方法 1. Context 类中的getSharedPreferences("文件名字",操作模式) 方法
操作模式一般两种 :
MODE_PRIVATE 只允许本进程使用
MODE_MULTI_PROCESS ('mʌltɪ)多的进程
方法 2. Activity类中的getSharedPreferences(操作模式) 方法
方法 3. PreferenceManager类中的getSharedPreferences()方法
写: SharedPreferences.Editor editor = PreferenceManager.getDefaultSharedPreferences(context).edit();
editor.putString("key",value);
读: SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
prefs.get("key","没有值时候默认")
三. SQLite
1.首先要创建一SQLiteOpenHelper数据库的辅助类,类中有a,b两个方法
a. onCreate()用于创建表 ,如
Public void onCreate(SQLiteDatabase db){
db.execSQL(创建表语句)
}
b.onUpgrade()
2.创建一个打开或现有的数据库
SQLiteOpenHelper msh = new SQLiteOpenHelper(content或this,DB_name,null,Version版本);
SQLiteDatabase db = msh.getwritableDatabase()
3.添加数据
// ContentValue类似hashMap
ContentValues contentValues = new ContentValues();
contentValues.put("key",values);
db.insert("表名",条件或null,contentValues)
4.查询数据
Cursor cursor = db.query("表名",null,null,null,null,null,null);
if(cursor.moToFirst()){
String data = cursor.getString(cursor.getColumnIndex("data"));
}while(cursor.moveToNext);
cursor.close();
5. 改正数据
db.update("表名",values,"data=?",new String[]{"new data"});
6.删除数据
db.update("表名","pages>?",new String[]{"500"}); //删除pages大于500的表
四. ContentProvide共享数据的存储
注意 : 通过 Context 中的 getContentResolver()方法获取到该类的实例, Uri对象来查询表中的数据
Uri 可以是 ContactsContract.CommonDataKinds.Phone.CONTENT_URI(读取联系人的权限)
1.内容 URI给内容提供器中的数据建立
了唯一标识符,它主要由两部分组成,权限(authority)和路径(path)
authority : 包名 + provider 比如 com.example.app.provider
path : 表名 比如table1
头部加上协议声明
URI 标准的格式写法:content://com.example.app.provider/table1
Uri uri = Uri.parse("content://com.example.app.provider/table1")
2.创建数据
ContentValues values = new ContentValues();
values.put("column1", "text");
getContentResolver().insert(uri, values);
3.查询数据
Cursor cursor = getContentResolver().query(uri,projection,selection,selectionArgs,sortOrder);
if (cursor != null) {
while (cursor.moveToNext()) {
String column1 = cursor.getString(cursor.getColumnIndex("column1"));
}
cursor.close();
}
4.修改数据
getContentResolver().update(uri, values, "column1 = ? and column2 = ?", newString[] {"text", "1"});
5.删除数据
getContentResolver().delete(uri, "column1 = ?", new String[] { "1" });
四(2) 自定义ContentProvider
1. 自定义类继承ContentProvider类,重新 onCreate() , query() , insert() ,update() , delete() , getType() 方法
自定义不用uri.parse(),但是首先要对比uri是否相等 uriMatcher.match(传入的uri) ,其次getType()是根据uri相等,返回 Uri 对象所对应的 MIME类型 .
MIME类型的规定 :
1. 必须以 vnd 开头。
2. 如果内容 URI 以路径结尾,则后接 android.cursor.dir/,如果内容 URI 以 id 结尾,
则后接 android.cursor.item/。
3. 最后接上 vnd.<authority>.<path>。比如vnd.android.cursor.dir/vnd.com.example.app.provider.table1
vnd.android.cursor.item/vnd. com.example.app.provider.table1
2. manifest.xml 文中声明
<provider
android:name = "比如com.example.databasetest.DatabaseProvider"
android:anthorities = "比如com.example.databasetest.provider"
/>
五.
通过网路的空间存储数据,比如上传文件和下载文件,有比如 用户资料的上传和下载核对
Android 五种存储方式个人总结的更多相关文章
- android五种存储方式
http://www.cnblogs.com/smalltigerlee/archive/2011/11/10/2244143.html
- Android五种数据存储方式
android 五种数据存储 :SharePreferences.SQLite.Contert Provider.File.网络存储 Android系统提供了四种存储数据方式.分别为:SharePre ...
- Android数据的四种存储方式
作为一个完成的应用程序,数据存储操作是必不可少的.因此,Android系统一共提供了四种数据存储方式.分别是:SharePreference.SQLite.Content Provider和File. ...
- Android开发_Android数据的四种存储方式
Android系统一共提供了四种数据存储方式.分别是:SharePreference.SQLite.Content Provider和File.由于Android系统中,数据基本都是私有的的,都是存放 ...
- Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (三) —— SharePreferences
除了SQLite数据库外,SharedPreferences也是一种轻型的数据存储方式,它的本质是基于XML文件存储key-value键值对数据,通常用来存储一些简单的配置信息.其存储位置在/data ...
- Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (二) —— SQLite
SQLite是一种转为嵌入式设备设计的轻型数据库,其只有五种数据类型,分别是: NULL: 空值 INTEGER: 整数 REAL: 浮点数 TEXT: 字符串 BLOB: 大数据 在SQLite中, ...
- [Android]Android数据的四种存储方式
存储方式 Android提供以下四种存储方式: SharePreference SQLite File ContentProvider Android系统中数据基本都是私有的,一般存放在“data/d ...
- (转)Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (三) —— SharePreferences
除了SQLite数据库外,SharedPreferences也是一种轻型的数据存储方式,它的本质是基于XML文件存储key-value键值对数据,通常用来存储一些简单的配置信息.其存储位置在/data ...
- [转][Android]Android数据的四种存储方式
android.database.sqlite类 SQLiteQueryBuilder java.lang.Object android.database.sqlite.SQLiteQueryBuil ...
随机推荐
- Silverlight中ListBox的数据绑定
在Silverlight中ListBox是一个非常强大的控件.总结下ListBox的绑定数据的方式. 首先,新建一个Book类, public class Book { public string B ...
- importlib模块与__import__详解
importlib模块与__import__都可以通过过字符串来导入另外一个模块,但在用法上和本质上都有很大的不同. 通过下面示例说明,有如下一个工程目录: name = 'test' def get ...
- yum whatprovides 查找哪个包可以提供缺失的文件
yum whatprovides 查找哪个包可以提供缺失的文件
- windows 系统无法启动windows event log 服务
windows 系统无法启动windows event log 服务 关键词:无法启动系统事件日志 尝试解决步骤 [1]权限:把如图中logsfile文件等都给local service [2]把C: ...
- 双舵轮AGV里程计、运动控制核心算法
舵轮AGV可以通过调整两个舵轮的角度及速度,可以使小车在不转动车头的情况下实现变道,转向等动作,甚至可以实现沿任意点为半径的转弯运动,有很强的灵活性. 因此在AGV行业,这种驱动方式应用很广,但是目前 ...
- EasyUI Progressbar 进度条
通过 $.fn.progressbar.defaults 重写默认的 defaults. 进度条(progressbar)提供了一种显示长时间操作进度的反馈.进度可被更新以便让用户知道当前正在执行的操 ...
- 前端页面汉子显示为问号,需修改 linux下面修改mysql 数据库的字符编码为utf8
设置MySQL数据库编码为UTF-8 登陆后查看数据库当前编码:SHOW VARIABLES LIKE 'char%'; 修改/etc/mysql/my.cnf (默认安装路径下) (标签下没有的添加 ...
- tcpdump-抓包工具-Linux
环境:VMware-Workstation-12-Pro,Windows-10,CentOS-6.9-x86_64,Xshell5 基本介绍 tcpdump是Linux自带的抓包工具,可以详细看到计算 ...
- stringbuffer 和 stringbuilder区别
stringbuffer 和 stringbuilder速度 小于 线程安全 线程非安全 单线程操作大量数据用stringbui ...
- python中的TCP及UDP
python中是通过套接字即socket来实现UDP及TCP通信的.有两种套接字面向连接的及无连接的,也就是TCP套接字及UDP套接字. TCP通信模型 创建TCP服务器 伪代码: ss = sock ...