【转】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 ...
随机推荐
- 迁移,移动.vagrant.d目录
默认在 C:\Users\***\.vagrant.d 然后下面有boxes目录 想迁移到其它目录 setx VAGRANT_HOME "/d/.vagrant.d/" setx ...
- PowerBuilder -- 结构类型(structure)
http://bbs.csdn.net/topics/3501120743楼答复 PB的structure分两种,全局的和局部的,两者只有作用域不同. 全局的在file/new/pb object/s ...
- ASP.NET动态网站制作(10)-- JQ(2)
前言:jq的第二节课. 内容: 1.管理选择结果: (1)获取元素个数:$("img").size():获取页面中所有“img”个数: (2)提取元素:$("img[ ...
- excel十几万行数据快速导入数据库研究(转,下面那个方法看看还是可以的)
先贴原来的导入数据代码: 8 import os os.environ.setdefault("DJANGO_SETTINGS_MODULE", "www.setting ...
- Maven 编译
pom.xml 添加插件 <build> <plugins> <plugin> <groupId>org.apache.maven.plugins< ...
- 【BZOJ4238】电压 DFS树
[BZOJ4238]电压 Description 你知道Just Odd Inventions社吗?这个公司的业务是“只不过是奇妙的发明(Just Odd Inventions)”.这里简称为JOI社 ...
- EasyPlayerPro Windows播放器读取xml配置文件中的特殊字符问题
问题被反馈 今日一客户反馈说播放不了带用户名密码的流, 奇怪,这个问题不存在啊-,按照客户的说法, 是将url地址保存在配置文件中,然后再打开EasyPlayerPro运行: 问题复现 在EasyPl ...
- 十分钟git-服务器搭建ssh登陆
QQ820688215 微信公众号: 1首先,创建一个操作系统用户 git,并为其建立一个 .ssh 目录. $ sudo adduser git $ su git $ cd $ mkdir .ssh ...
- POJ 3714 Raid 近期对点题解
版权声明:本文作者靖心,靖空间地址:http://blog.csdn.net/kenden23/.未经本作者同意不得转载. https://blog.csdn.net/kenden23/article ...
- 蓝牙 CTS 测试
安装蓝牙测试安装包 之后 . 安卓包名字 android-cts-6.0_r19-linux_x86-x86.zip 解压之后 /cts/android-cts/tools/ 目录下 运行 ./ ...