


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Android SQLite解析说到SQLite,无论C+、Java程序员还是其他的非主流程序员,应该都听说过它,可见其非常流行。SQLite是轻量级的、嵌入式的、关系型数据库,目前已经在iPhone、Android等手机系统中使用,而且被其他的公司广泛使用,比如说:Adobe,具体SQLite的介绍可以到其官方网站浏览。在学习Android SQLite前,必须对SQL语句有很深入的了解(如果忘记了,利用这次机会好好复习下)。关于数据库、表的创建等基础知识,由于篇幅有限就不在此详细说明,主要说明数据库的4大基本操作:添加(insert)、删除(delete)、查询(query)、修改(update),这是在学习Android SQLite的过程中最为关注的部分。除了这4大操作以外,我们还需要注意的地方就是:获取查询结果的记录集(Recordset)。Android SQLite分析等有了这些基本概念,再来学习Android SQLite,从Android SDK中摘要如下:首先关注到的是SQLiteDatabase类,在Android SDK中看其详细说明,其主要接口如下:返回值函数原型longinsert(String table, String nullColumnHack, ContentValues values)Convenience method for inserting a row into the database.Intdelete(String table, String whereClause, String whereArgs)Convenience method for deleting rows in the database.Cursorquery(String table, String columns, String selection, String selectionArgs, String groupBy, String having, String orderBy, String limit)Query the given table, returning a Cursor over the result set.Intupdate(String table, ContentValues values, String whereClause, String whereArgs)Convenience method for updating rows in the database.看到这些是不是感到似曾相识了?不错,这就是数据库的4大基本操作:添加(insert)、删除(delete)、查询(query)、修改(update)。感觉轻松很多了,再仔细看下这些函数的参数,发现很多参数都是按照SQL语句定义的,例如:select * from p_employee where id 9999 order by id asc需要额外说明2个数据结构: ContentValues,Cursor;ContentValues就相当于C+中的map(String key, Integer value),其主要接口包括put(),get()。再结合insert操作的主要目的:按照表中数据段将对应的数据项写入到表中,就可以看出来ContentValues主要是存放表中每个表的数据段,以及其对应的值。Cursor也就是前面说的:查询结果的记录集。从记录集的特征可以想到其包含的操作应该有:MoveFirst()、MoveLast()、MoveNext()、Move()、IsLast()、GetColumns()等,而且它还是个抽象类abstract class,SQLiteCursor就是其具体的实现。关于SQLiteDatabase类,其他值得关注的函数是:Create()、execSQL()。至于其他的函数,比如beginTransaction(),endTransaction()等关于数据库同步操作的函数,就只有在使用的过程中深入了解。额外补充说明最后值得一提的是:一个很好的辅助类SQLiteOpenHelper,其简化了数据库的操作。按照Android SDK文档中的说明,也可以通过继承此类、改写其接口的方法来实现对数据库的操作,SQLiteOpenHelper,其主要接口如下:仔细分析其说明,发现这个类主要是创建一个数据库,并对数据库的版本进行管理。当在程序中调用这个类的方法getWritableDatabase()或者getReadableDatabase()方法的时候,如果当时没有数据库,那么Android系统就会自动创建一个数据数据库。其他辅助说明 所有的数据库文件存放在手机中的/data/data/package_name/databases路径下。最为重要的一点是:在Android中,所有的应用软件的数据(包括文件、数据库)为该应用软件所私有的,如果需要在不同的应用中共享数据,必须使用ContentProvider实现,一个ContentProvider类实现了一组标准的方法接口,从而能够让其他的应用保存或读取此ContentProvider的各种数据类型。 为了方便测试,如何查看SQLite数据库的内容?使用Android SDK提供的工具:sqlite3.exe。这是一个命令行实用工具,列举主要使用的命令如下:查看表结构sqlite3 “path” .dump例如G:androidandroid-sdk-windowtoolssqlite3 30m.db3 .bump,运行结构如下:BEGGIN TRANSACTION;CREATE TABLE TmProgramm (index INTEGER,nID INTEGER, nChannelID INTEGER,strTitle CHAR(255),dwDuration INTEGER, strThumbNail CHAR(1024),strURL CHAR(255),strPathName CHAR(255),strAuthor CHAR(255),dwSize INTEGER,State INTEGER,Percent INTEGER,strConverted CHAR(255),dwVideoType INTEGER,dwDownloadedBytes INTEGER,strTime CHAR(255),strHTTPVersion CHAR(255),strUser
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 养老院奉献爱心倡议书
- 努力的感言15篇
- 2025年上半年安徽交控集团所属交控资源公司招聘7人考前自测高频考点模拟试题及答案详解参考
- 2025年安徽理工大学公开招聘电气与工程学院副院长考前自测高频考点模拟试题及一套完整答案详解
- 2025年《中国烟草》杂志社有限公司(中国烟草总公司传媒中心)招聘考前自测高频考点模拟试题及答案详解(网校专用)
- 2025年5月广西师范大学劳动合同制员工招聘1人考前自测高频考点模拟试题参考答案详解
- 2025年滨州市面向社会公开招聘硕博士高层次人才(168人)模拟试卷及参考答案详解1套
- 2025年海上风力发电场运维成本效益分析与技术创新策略报告
- 2025年数字人民币跨境支付技术合规性与监管策略研究报告
- 2025年环保型表面处理技术在环保产业政策支持下的创新发展报告
- 肿瘤微环境中的细胞间通信
- 麦肯锡商业计划书模板
- 项目经理职业生涯规划
- 除锈剂MSDS参考资料
- 高一英语选择性必修一课文及翻译(外研版新教材)中英Word精编文档
- 社会调查研究抽样课件
- 消防管道支架工程量计算表
- 应用成型的双面彩钢板复合风管代替传统的铁皮风管
- JJF(石化)006-2018漆膜弹性测定器校准规范
- 东华软件需求调研提纲汇总版与03-02同步
- 全国优质课一等奖初中数学《有理数的乘方》精品课件
评论
0/150
提交评论