全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 垃圾填埋场渗滤液沉淀池优化设计
- 城市道路提升改造工程技术方案
- 风电场环境保护与生态恢复方案
- 兵团法院公务员考试试题及答案
- 巴中市柳林镇公务员考试试题及答案
- 安全技术管理公务员考试试题及答案
- 城市道路环境整治提升改造项目规划设计方案
- 2026年蔬菜种植公司绿禾蔬菜品牌建设与宣传推广制度
- 文化产业市场分析:影视出版与动漫产业研究
- 2025浙江杭州市余杭区瓶窑镇巡查执法辅助人员招考易考易错模拟试题(共500题)试卷后附参考答案
- 餐饮服务标准操作流程SOP模板
- 新解读(2025)《HG-T 3985-2007聚四氟乙烯波纹管膨胀节》
- 勘察设计安全管理计划及保证措施
- 2025中考数学复习之挑战压轴题-图形的相似
- 教师专业成长路径规划与执行方案
- 2025四川广元市社会化选聘新兴领域党建工作专员28人考试参考试题及答案解析
- 工地消防常识培训课件
- 酒店特色菜品推广方案
- 金融业务授权管理标准体系构建
- 2025年煤矿安全规程题库(含答案)
- 施工单位安全生产责任制范本
评论
0/150
提交评论