课程目标:

掌握Android中数据存储的几种方式

熟练使用PreferenceActivity&PreferenceScreen做专业的Setting功能

熟练使用SQLite3来存储数据

深入研究SQLite3数据库特性,并且比对与大型数据库的包括存储过程,主外键关联等特性

了解文件存储的内外存储分别  了解网络存储C/S结构原理 。

重点难点:SQLiteOpenHelper类的使用   SQLIte数据库的特性掌握

考核目标:

说出Android数据存储的几种形式 ?

Sqlite3能支持存储过程么,支持主外键关联么 ?

如何让自己的Setting程序与系统的Setting程序融合

一、Android数据存储初探

XML              Share Preference

Binary File     File  <使用内部存储,使用扩展存储>

关系型数据库   SQLite3

网络访问         Network <Socket , Http,Https>

二、SharedPreference

2.1 最基本操作步骤

1)   getSharedPreference

2)   get SharedPreferences.Editor

3)   Editor.commit()。

2.2 三种方式得到preference区别

1) public SharedPreferences getPreferences (int mode)

通过Activity对象获取,获取的是本Activity私有的Preference,保存在系统中的xml形式的文件的名称为这个Activity的名字,因此一个Activity只能有一个,属于这个Activity。

2) public SharedPreferences getSharedPreferences (String name, int mode)

因为Activity继承了ContextWrapper,因此也是通过Activity对象获取,但是属于整个应用程序,可以有多个,以第一参数的name为文件名保存在系统中。

3)public static SharedPreferences getDefaultSharedPreferences (Context context)

PreferenceManager的静态函数,保存PreferenceActivity中的设置,属于整个应用程序,但是只有一个,Android会根据包名和PreferenceActivity的布局文件来起一个名字保存。

2.3 打造专业的User Preference

PreferenceActivity

PreferenceScreen..

. setOnPreferenceChangeListener...

2.4 如何嵌套系统preference

 

2.5 Subtopic

三、SQLite3

3.1 SQLite数据库简介

SQLite (http://www.sqlite.org/),是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。SQLite第一个Alpha版本诞生于2000年5月. 至今已经有10个年头,SQLite也迎来了一个版本 SQLite 3已经发布。

特征:轻量级,独立性,隔离性,跨平台,多语言接口,安全性。

3.2 总结

SQLite 是一个全面而又完整支持sql语句的文件型数据库

Sqlite 支持 事务 , 视图 , 索引,触发器 ,主外键约束

默认的必须给每张表的主键名字为_id

SqliteDatabase 可以用封装的insert ,update ,delete ,query 方法 ,也可以用execSql , rawSql 等原生方法

3.3 SQLiteOpenHelper

getReadableDatabase()

getWritableDatabase()

onCreate(SQLiteDatabase db , int oldVersion, int newVersion)

onOpen(SQLiteDatabase db)

onUpgrade(SQLiteDatabase db)

1)通过Helper , 建立好数据库表结构 - onCreate , onUpgrade。

2)调用helper实例 , 通过get***Database()得到DB对象。

3)通过DB对象实例来调用增删改查 ,insert()。

3.4 建立数据库,更新数据库: adb shell 看数据库

 

3.5 具体的数据操作:Add,Update,Search,Delete,批量更新和删除。

 

3.6 我们思考一下Sqlite3数据库引擎在哪儿? external/sqlite

思路:

如你来移植,对开源的项目,你是编译好类库放上来还是直接源码都放上来呢?

如果源码放上来,我们去官网下载源码 , 打开看看

去搜索一下源码

找到地址 。

3.7 我们来思考一下SQlite3连接方式实际是什么? libcore/sqlite-jdbc

 

3.8 表的主外键关系

3.9 表的视图

3.10 表的触发器,存储过程

3.11 Sqlite事务

beginTransaction

setTransactionSuccessful

endTransaction

10、Android数据存储的更多相关文章

  1. Android数据存储之SQLCipher数据库加密

    前言: 最近研究了Android Sqlite数据库(文章地址:Android数据存储之Sqlite的介绍及使用)以及ContentProvider程序间数据共享(Android探索之ContentP ...

  2. Android数据存储之GreenDao 3.0 详解

    前言: 今天一大早收到GreenDao 3.0 正式发布的消息,自从2014年接触GreenDao至今,项目中一直使用GreenDao框架处理数据库操作,本人使用数据库路线 Sqlite----> ...

  3. 【Android开发日记】之入门篇(七)——Android数据存储(上)

    在讲解Android的数据源组件——ContentProvider之前我觉得很有必要先弄清楚Android的数据结构. 数据和程序是应用构成的两个核心要素,数据存储永远是应用开发中最重要的主题之一,也 ...

  4. Android数据存储方式--SharedPreferences

    Android数据存储方式有如下四种:SharedPreferences.存储到文件.SQLite数据库.内容提供者(Content provider).存储到网络服务器. 本文主要介绍一下Share ...

  5. Android数据存储-通过SharedPreferences实现记住密码的操作

    在Android中登陆中,为了实现用户的方便,往往需要根据用户的需要进行记住密码的操作,所以,在Android数据存储中SharedPreferences恰恰可以实现这一点 下面,小编将带领大家通过S ...

  6. Android - 数据存储 -存储文件

    Android使用的文件系统和其他平台的基本磁盘的文件系统很相似.这里将要介绍如何使用File API在Android文件系统中读写文件. File对象适合按顺序读写大量的数据.例如,适合图片文件或者 ...

  7. Android - 数据存储 -存储键值对

    如果你有少量的键值数据需要存储,可以使用SharedPreferencesAPI.SharedPreferences对象指向一个包含键值对的文件并且提供了一些简单的方法来读取它们.每个SharedPr ...

  8. Android数据存储五种方式

    1 使用SharedPreferences存储数据:常用于做本地缓存 2 文件存储数据:(1)data/data/<package name>/files目录内   (2)SDCard内 ...

  9. Android数据存储:SDCard

    Android数据存储之SDCard 0.获取sd卡路径. 1.讲述 Environment 类. 2.讲述 StatFs 类. 3.完整例子读取 SDCard 内存 0.获取sd卡路径 方法一: p ...

随机推荐

  1. 【BZOJ 1070】[SCOI2007]修车

    Description 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的.现在需要安排这M位技术人员所维修的车及顺序,使 ...

  2. 微软职位内部推荐-Principal DEV Manager for Bing Client

    微软近期Open的职位: Title: Principal DEV Manager for Bing ClientGroup: Search Technology Center Asia, BingW ...

  3. python学习笔记4(列表)

    列表是最通用的Python复合数据类型,列表中包含以逗号分隔,并在方括号([])包含的项目. 在一定程度上,列表相似C语言中的数组,它们之间的一个区别是,所有属于一个列表中的项目可以是不同的数据类型的 ...

  4. Csharp volatile 关键字

    volatile 关键字指示一个字段可以由多个同时执行的线程修改.声明为 volatile 的字段不受编译器优化(假定由单个线程访问)的限制.这样可以确保该字段在任何时间呈现的都是最新的值. vola ...

  5. 现在不使用ZeroClipboard我们也能实现复制功能(转)

    现在不使用ZeroClipboard我们也能实现 首先,我们保证页面结构不变,但不在引入ZeroClipboard插件: 1 <input type="text" name= ...

  6. LocalStorage 本地存储

    首先自然是检测浏览器是否支持本地存储.在HTML5中,本地存储是一个window的属性,包括localStorage和sessionStorage,从名字应该可以很清楚的辨认二者的区别,前者是一直存在 ...

  7. 【概率】COGS 1487:麻球繁衍

    Description 万有引力定律: “使物体相互靠近的力的大小与物体的质量成正比——而物体的质量又由同一种力决定.这是一个有趣并且有益的例子,说明了科学是如何用A证明B,再用B证明A的.”——安布 ...

  8. Extjs 4 chart自定义坐标轴刻度

    Sencha出品的ExtJs是一个非常优秀的前端框架,尤其是具有里程碑意义的4.0的发布.4.0采用MVC架构和全新的class系统,并且提供了非常丰富的组件.但是,尽管ExtJS如此强大,仍有不尽人 ...

  9. hdu 4577 X-Boxes 大数

    java水过…… 代码如下: import java.math.*; import java.util.*; public class Main { public static void main(S ...

  10. 5.查找最小的k个元素(数组)

    题目: 输入n个整数,输出其中最小的k个,例如输入1,2,3,4,5,6,7,8这8个数,则最小的4个是1,2,3,4(输出不要求有序) 解: 利用快速排序的partition,算导上求第k大数的思想 ...