一 . 文件存储

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. ubuntu 安装搜狗

    先按照这个选择fcitx: https://blog.csdn.net/qq_40563761/article/details/82664851 然后重启 右上角会出现键盘图片点击选configura ...

  2. Nginx 设置临时维护页面

    Nginx 设置临时维护页面 http://www.myexception.cn/open-source/1753957.html http://blog.justwd.net/snippets/ng ...

  3. POJ2891:Strange Way to Express Integers(解一元线性同余方程组)

    写一下自己的理解,下面附上转载的:若a==b(modk);//这里的==指的是同余,我用=表示相等(a%k=b)a-b=kt(t为整数)以前理解的错误思想:以前认为上面的形式+(a-tb=k)也是成立 ...

  4. 基因芯片与NGS区别[转载]

    转自:http://blog.sina.com.cn/s/blog_40d4ae110101fjzy.html 1 二代测序与基因芯片的区别与优缺点. 生物芯片相对第二代测序而言,优势在于价格便宜,便 ...

  5. mydumper/myloader使用详解

      mydumper安装:http://www.cnblogs.com/lizhi221/p/7010174.html mydumper原理:http://www.cnblogs.com/lizhi2 ...

  6. 数据挖掘-逻辑Logistic回归

    逻辑回归的基本过程:a建立回归或者分类模型--->b 建立代价函数 ---> c 优化方法迭代求出最优的模型参数  --->d 验证求解模型的好坏. 1.逻辑回归模型: 逻辑回归(L ...

  7. js cookie的读写

    cookie是一小段信息,以键/值对的信息保存在计算机硬盘上的字符串, cookie存储容量大概在4kb,不同的浏览器厂家对cookie大小的限制有微微的差异:cookie主要的本质是“识别”,通过识 ...

  8. mysql 分组统计SQL语句

    1.按照特定字段: 2.在某一日期范围内: 3.按日.按月统计: 4.动态传入数据库表名称. select <if test="dateType=="d"" ...

  9. GPS数据解析

    1.摘要 GPS模块使用串口通信,那么它的的数据处理本质上还是串口通信处理,只是GPS模块的输出的有其特定的格式,需要字符串处理逻辑来解析其含义.如何高效的处理从GPS模块接收到的数据帧,是GPS驱动 ...

  10. STM32端口输入输出模式配置

    STM32的IO口模式配置 根据数据手册提供的信息,stm32的io口一共有八种模式,他们分别是: 四种输入模式 上拉输入:通过内部的上拉电阻将一个不确定的信号通过一个电阻拉到高电平. 下拉输入:把电 ...