• 【转】Pro Android学习笔记(五):了解Content Provider(上)


    Content Provider是抽象数据封装和数据访问机制,例如SQLite是Android设备带有的数据源,可以封装到一个content provider中。要通过content provider进行读写,需要使用URI。推荐阅读Android学习笔记(四七):Content Provider初谈和Android联系人信息Android学习笔记(四八):提供自己的Content ProviderAndroid学习笔记(四九):通过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:developeradt-bundle-windows-x86adt-bundle-windows-x86-20130522sdk
    PATH=%PATH%;%SDKPATH% ools;%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

  • 相关阅读:
    [转]oracle数据库定时任务dbms_job的用法详解
    身份证号码的正则表达式及验证详解(JavaScript,Regex)
    js数组操作
    jq滚动到底部加载更多方法
    jq之实现轮播
    node之npm一直出错
    Jq之21点游戏
    移动端屏幕适配viewport
    meta属性
    用户体验之表单结构
  • 原文地址:https://www.cnblogs.com/blongfree/p/5047533.html
Copyright © 2020-2023  润新知