一 . 文件存储

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 五种存储方式个人总结的更多相关文章

  1. android五种存储方式

    http://www.cnblogs.com/smalltigerlee/archive/2011/11/10/2244143.html

  2. Android五种数据存储方式

    android 五种数据存储 :SharePreferences.SQLite.Contert Provider.File.网络存储 Android系统提供了四种存储数据方式.分别为:SharePre ...

  3. Android数据的四种存储方式

    作为一个完成的应用程序,数据存储操作是必不可少的.因此,Android系统一共提供了四种数据存储方式.分别是:SharePreference.SQLite.Content Provider和File. ...

  4. Android开发_Android数据的四种存储方式

    Android系统一共提供了四种数据存储方式.分别是:SharePreference.SQLite.Content Provider和File.由于Android系统中,数据基本都是私有的的,都是存放 ...

  5. Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (三) —— SharePreferences

    除了SQLite数据库外,SharedPreferences也是一种轻型的数据存储方式,它的本质是基于XML文件存储key-value键值对数据,通常用来存储一些简单的配置信息.其存储位置在/data ...

  6. Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (二) —— SQLite

    SQLite是一种转为嵌入式设备设计的轻型数据库,其只有五种数据类型,分别是: NULL: 空值 INTEGER: 整数 REAL: 浮点数 TEXT: 字符串 BLOB: 大数据 在SQLite中, ...

  7. [Android]Android数据的四种存储方式

    存储方式 Android提供以下四种存储方式: SharePreference SQLite File ContentProvider Android系统中数据基本都是私有的,一般存放在“data/d ...

  8. (转)Android数据的四种存储方式SharedPreferences、SQLite、Content Provider和File (三) —— SharePreferences

    除了SQLite数据库外,SharedPreferences也是一种轻型的数据存储方式,它的本质是基于XML文件存储key-value键值对数据,通常用来存储一些简单的配置信息.其存储位置在/data ...

  9. [转][Android]Android数据的四种存储方式

    android.database.sqlite类 SQLiteQueryBuilder java.lang.Object android.database.sqlite.SQLiteQueryBuil ...

随机推荐

  1. Silverlight中ListBox的数据绑定

    在Silverlight中ListBox是一个非常强大的控件.总结下ListBox的绑定数据的方式. 首先,新建一个Book类, public class Book { public string B ...

  2. importlib模块与__import__详解

    importlib模块与__import__都可以通过过字符串来导入另外一个模块,但在用法上和本质上都有很大的不同. 通过下面示例说明,有如下一个工程目录: name = 'test' def get ...

  3. yum whatprovides 查找哪个包可以提供缺失的文件

    yum whatprovides 查找哪个包可以提供缺失的文件

  4. windows 系统无法启动windows event log 服务

    windows 系统无法启动windows event log 服务 关键词:无法启动系统事件日志 尝试解决步骤 [1]权限:把如图中logsfile文件等都给local service [2]把C: ...

  5. 双舵轮AGV里程计、运动控制核心算法

    舵轮AGV可以通过调整两个舵轮的角度及速度,可以使小车在不转动车头的情况下实现变道,转向等动作,甚至可以实现沿任意点为半径的转弯运动,有很强的灵活性. 因此在AGV行业,这种驱动方式应用很广,但是目前 ...

  6. EasyUI Progressbar 进度条

    通过 $.fn.progressbar.defaults 重写默认的 defaults. 进度条(progressbar)提供了一种显示长时间操作进度的反馈.进度可被更新以便让用户知道当前正在执行的操 ...

  7. 前端页面汉子显示为问号,需修改 linux下面修改mysql 数据库的字符编码为utf8

    设置MySQL数据库编码为UTF-8 登陆后查看数据库当前编码:SHOW VARIABLES LIKE 'char%'; 修改/etc/mysql/my.cnf (默认安装路径下) (标签下没有的添加 ...

  8. tcpdump-抓包工具-Linux

    环境:VMware-Workstation-12-Pro,Windows-10,CentOS-6.9-x86_64,Xshell5 基本介绍 tcpdump是Linux自带的抓包工具,可以详细看到计算 ...

  9. stringbuffer 和 stringbuilder区别

    stringbuffer  和  stringbuilder速度                 小于         线程安全           线程非安全 单线程操作大量数据用stringbui ...

  10. python中的TCP及UDP

    python中是通过套接字即socket来实现UDP及TCP通信的.有两种套接字面向连接的及无连接的,也就是TCP套接字及UDP套接字. TCP通信模型 创建TCP服务器 伪代码: ss = sock ...