【转】Pro Android学习笔记(五):了解Content Provider(上)
Content Provider是抽象数据封装和数据访问机制,例如SQLite是Android设备带有的数据源,可以封装到一个content provider中。要通过content provider进行读写,需要使用URI。推荐阅读Android学习笔记(四七):Content Provider初谈和Android联系人信息、Android学习笔记(四八):提供自己的Content Provider和Android学习笔记(四九):通过Content Provider访问数据。Content Provider的重要作用实现应用之间的数据共享,而对于应用内的数据访问,Android提供多种方式,有Preferences,文件,SQLite,以及通过HTTP服务访问Internet。
Android有些内置content Provider,我们可以在android.provider软件包中查看,如contact,mediastore,如非内置,则必须通过content provider接口实现。
Android的数据库
SQLite是内容提供者常用的数据源。我们可以使用Android和SQLite的命令来对SQLite数据进行处理,这些命令位于/sdk/tools和/sdk/platform-tools中。为了方便使用这些命令,我们在Windows中设置脚本文件myandroid.bat,进行环境变量的设置。而在Linux中,则可以通过export PATH=$PATH:$HOME/...来进行设置。
set SDKPATH=D:\developer\adt-bundle-windows-x86\adt-bundle-windows-x86-20130522\sdk
PATH=%PATH%;%SDKPATH%\tools;%SDKPATH%\platform-tools
Android提供了adb命令,可以对模拟器或所连接的设备进行操作。adb,即Android Debug Bridge,详细命令可以在http://developer.android.com/tools/help/adb.html中阅读。
在前面我们已经学过使用adb devices来查看当前有效的设备。如果没有连接设备或者没有开启模拟器,我们可以通过emulator @avdname来开启模拟器,而avdname是AVD的名称,有效的avdname可以通过android list avd命令来查看,当然我们可以通过eclipse来打开。

通过下面命令对所连接设备或模拟器进行操作。
adb shell
进去后,我们可以通过ls /system/bin查看可使用的命令。数据信息存放在/data/data目录下,按安装包来分类。我们可以通过ls –R /data/data/*/databases看看那些包下面有SQLite数据库。例如Android内置的一些DB。

这些*.db文件是就SQLite数据库。在Android数据库通常在第一次访问的时候创建。要接近数据库采用:
sqlite3 /data/data/<包名。例如com.android.providers.contacts>/databases/<数据库文件:contacts.db>
下面是一些常用SQLite命令:
sqlite>.exit 退出sqlite
sqlite>.tables 显示tables列表
可使用SQL语言,一样要在最后加上分号。


从上图中看,.schema table_name给出的内容很不直观,我们可以将*.db文件拷贝出来,用专门的数据库工具来查看,例如sqliteman,也可以在本地通过sqlite3命令进行操作。将文件拖出来的命令如下,不填写<本地路径>,则为当前目录。

常用SQL语言
记录一些常用的SQL语言。
select * from table1;
select count(*) from table1;
select col1, col2 from table1;
select distinct col1 from table1;
select count(col1) from (select distinct col1 from table1);
select count(*), col1 from table1 group by col1;
select * from table1 t1, table2 t2 where t1.col1 = t2.col1;
select * from table t1 left outer join table2 t2 on t1.col1 = t2.col1 where ....
相关链接: 我的Android开发相关文章
转自http://blog.csdn.net/flowingflying/article/details/9185809
【转】Pro Android学习笔记(五):了解Content Provider(上)的更多相关文章
- 【转】 Pro Android学习笔记(五六):配置变化
目录(?)[-] Activity的destorycreate过程 Fragment的destorycreate过程 onSaveInstanceState saveFragmentInstanceS ...
- 【转】 Pro Android学习笔记(五二):ActionBar(5):list模式
可以在action bar中加入spinner的下来菜单,有关spinner,可以参考Pro Android学习笔记(二十):用户界面和控制(8):GridView和Spinner. list的样式和 ...
- 【转】Pro Android学习笔记(二五):用户界面和控制(13):LinearLayout和TableLayout
目录(?)[-] 布局Layout 线性布局LinearLayout 表格布局TableLayout 布局Layout Layout是容器,用于对所包含的view进行布局.layout是view的子类 ...
- 【转】 Pro Android学习笔记(五五):调试和分析(3):adb命令、模拟器控制台和StrictMode
目录(?)[-] adb命令 模拟器Console StrictMode adb命令 我们在学习SQLite的使用,介绍过部分adb命令的使用,见Pro Android学习笔记(五):了解Conten ...
- 【转】 Pro Android学习笔记(二二):用户界面和控制(10):自定义Adapter
目录(?)[-] 设计Adapter的布局 代码部分 Activity的代码 MyAdapter的代码数据源和构造函数 MyAdapter的代码实现自定义的adapter MyAdapter的代码继续 ...
- 【转】 Pro Android学习笔记(四十):Fragment(5):适应不同屏幕或排版
目录(?)[-] 设置横排和竖排的不同排版风格 改写代码 对于fragment,经常涉及不同屏幕尺寸和不同的排版风格.我们在基础小例子上做一下改动,在横排的时候,仍是现实左右两个fragment,在竖 ...
- 【转】 Pro Android学习笔记(十九):用户界面和控制(7):ListView
目录(?)[-] 点击List的item触发 添加其他控件以及获取item数据 ListView控件以垂直布局方式显示子view.系统的android.app.ListActivity已经实现了一个只 ...
- Pro Android学习笔记 ActionBar(1):Home图标区
Pro Android学习笔记(四八):ActionBar(1):Home图标区 2013年03月10日 ⁄ 综合 ⁄ 共 3256字 ⁄ 字号 小 中 大 ⁄ 评论关闭 ActionBar在A ...
- 【转】 Pro Android学习笔记(八二):了解Package(1):包和进程
文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注册等附加条件.转载须注明出处:http://blog.csdn.net/flowingflying/ 在之前,我们已经学习了如何签发apk,见P ...
- 【转】 Pro Android学习笔记(六七):HTTP服务(1):HTTP GET
目录(?)[-] HTTP GET小例子 简单小例子 出现异常NetworkOnMainThreadException 通过StrictMode进行处理 URL带键值对 Andriod应用可利用ser ...
随机推荐
- Linux进入单用户模式
有时候配置linux的过程中,因为一些误操作导致系统初始化时堵塞或挂起而无法进入系统,原因往往是因为配置文件设置错误,部分文件被误删之类.遇到这种情况一般新手的做法就是重装(虚拟机不装白不装),但在实 ...
- 2014年java软件project师面试题收集
如果页面中于五个li标签.写个js使点击每个li返回他的index <!doctype html> <html> <head> <style> li{c ...
- Emgu安装配置及使用
前言:项目需要,需使用图像处理来完成机械臂从运动的皮带上抓取物体的功能,所以又重拾视觉与图像处理内容. 内容:Emgu是OpenCV的一个跨平台的.NET封装,结构如下图所示: 下载地址:http:/ ...
- 限制UITextView的字数和字数监控,表情异常的情况和禁用表情
限制UITextView的字数和字数监控,表情异常的情况和禁用表情 3523FD80CC4350DE0AE7F89A8532B9A8.png 因为字数占一个字符,表情占两个字符.你要是限制15个字 ...
- EasyPlayer_Android RTSP安卓播放器直播画面卡在第一帧问题修复
最近发现某些Android安卓手机在运行EasyPlayer播放视频时,会停留在第一帧画面,虽然有码率预示着接收端没有问题,但是画面却卡着不动. 一般来讲,这个现象有三种原因导致: 没有接收到视频帧; ...
- android菜鸟学习笔记11----Intent的两点补充
关于Intent的两点补充: 1.隐式Intent启动组件,会有一个Intent解析的过程,若找不到能够处理该Intent的组件,程序就会异常终止.一个合理的做法是,在使用Intent实例启动组件如: ...
- 关于BlockingQueue
1 什么是BlockingQueue 2 BlockingQueue有什么用 3 ArrayBlockingQueue的用途 1 它是一个线程安全的队列 2 它是一个容量固定的队列 3 它为什么叫bl ...
- JavaScript如何判断非空
JavaScript判断非空的语句一般为: var elvis; if (typeof elvis !== "undefined" && elvis !== nul ...
- SVN支干合并(转载)
分支用来维护独立的开发支线,在一些阶段,你可能需要将分支上的修改合并到最新版本,或者将最新版本的修改合并到分支. 此操作十分重要,在团队开发中,如果你是SVN 的维护者此环节可以说是必不可少,因为团队 ...
- ABAP HTTP POST
1.HTTP DATA: lo_http_client TYPE REF TO if_http_client, lv_service TYPE string, lv_result TYPE strin ...