《基于android平台的个人旅游系统的设计与实现大学本科毕业论文.doc》由会员分享,可在线阅读,更多相关《基于android平台的个人旅游系统的设计与实现大学本科毕业论文.doc(32页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、基于Android平台的个人旅游系统的设计与实现摘要 随着社会经济发展,人们生活工作改善、闲暇时间增多,极大地促进了旅游活动的迅猛发展。旅游业成为当今世界上发展速度最快,发展势头最强劲的新兴产业之一。以全球数字化信息网络高速发展为背景, 通过基于位置和地图信息技术的结合来帮助旅游者更快地获取旅游景点相关信息,更好地分享旅游过程的点点滴滴,成为人们的迫切需要。本课题将旅游产品和智能终端结合,提出了一种基于Android平台的旅游系统的设计与实现方案。该系统使用Eclipse和Android SDK为开发环境,开发旅游应用软件,实现多媒体应用、电子地图、游记记录等功能。多媒体应用支持旅游景点的图片
2、浏览。电子地图模块实现了百度地图在终端设备的展示和对终端设备的定位。游记记录模块利用Android自带的SQLite数据库,实现了游记录入、修改、展示等功能。该系统采用Android SDK,Eclipse作为开发工具。关键词:Android;旅游系统;智能终端摘要IAbstractII1绪论11.1课题背景11.2旅游系统的发展11.3本文主要工作22 Android系统简介32.1 Android系统概述32.2 Android系统架构42.3 Android开发环境配置62.4 Android程序开发92.4.1 程序开发组件92.4.2 程序界面开发122.5 Android系统数据存
3、储方式143 SQLite数据库143.1 SQLite主要语法153.1.1 结构新建153.1.2 结构删除153.1.3 数据操作153.1.4 事务处理163.2 SQLite内置函数163.3 SQLite常用操作173.3.1 数据库文件的打开和关闭173.3.2 数据库文件的查询184旅游系统的设计与实现214.1 数据库设计224.2 系统详细功能设计224.2.1 功能实现224.2.2 程序运行截图275 结论与展望27参考文献29致谢291绪论1.1课题背景 旅游是人类社会发展到一定阶段后的社会活动,是人们为了满足其休憩、消遣、文化和商务等活动的需要好离开自己定居地前往旅
4、游目的地并在那里做短暂停留的访问活动,而旅游产业是在旅游活动上发展而来的综合性产业,以游客为服务对象,以游客需求为中心,是一门资源密集型、服务综合性、发展依托型新型产业。旅游产业主要包括6大产业,分别是旅行社业、旅游交通业、住宿餐饮业、景点景区业、娱乐业、购物业,形成一个完整的产业链,共同为游客提供全方面的服务。 我国幅员辽阔,历史悠久,地理环境和人文环境多种多样,具有良好的旅游资源,为旅游产业的发展奠定了坚实的基础。随着全面建设小康社会的推进、人民生活水平的不断提高以及对外交流的不断深入,旅游消费需求正在大幅提升,旅游业已经成为我国发展最快的产业之一,成为国民经济中规模较大、产出水平较高的新
5、型产业。以入境游游客数为例,从1978年到2013年,我国的入境游人数增加了69倍,而入境游收入也不断攀升。然而现阶段我国旅游业存在信息化水平低,旅游产品开发水平低的问题,比如导游系统依然大多数停留在人工阶段(如靠旗帜和扩音器)、绝大多数的电子旅游系统集成度低,仅仅能提供如音频等应用,而对于更丰富的服务,如视频、图片、电子地图、地理信息位置等服务的功能都无法提供。另一方面,随着以谷歌公司的Android系统和苹果公司IOS系统为代表的智能操作系统日益得到大规模地应用和发展,智能终端被广泛用于移动终端、媒体播放器、消费电子等领域。从而以全球数字化信息网络高速发展为背景,通过基于位置和地图信息技术
6、的结合来帮助旅游者更快地获取旅游景点相关信息,更好地分享旅游过程的点点滴滴,成为人们的迫切需要。1.2旅游系统的发展 旅游信息化已在世界发达国家经历了几十年的发展,涉及到旅游目的地信息、旅游企业服务信息、旅游政府监督信息、旅游者个人信息、旅游产品信息五大类,综合复杂,范围较广。随着理论的不断进步,这前后也经历了几次大的信息技术应用变革。第一次是 1959 年美利坚航空公司和 IBM 公司联合开发了世界上第一个计算机定位系统 SABRE,这是旅游业信息化萌芽的标志;第二次是 1978 年美国推出的航空管制取消法案,增大了旅游者购买机票的选择范围,并使得计算机预订系统延伸到旅行代理商;第三次是到
7、1994 年底,美国开始出现新式的“电子机票”,实行“无票旅行”方式。在信息技术迅猛发展的大环境下,旅游系统也快速发展, 2005 年 Google 公司推出的谷歌地图就是典型的代表。 我国旅游业信息化开始于 20 世纪 80 年代初期,起步比较晚,基础比较薄弱,整体化水平相对比较低。但国内许多学者在国外学者研究的基础上,进行了大量的探讨,提出了一些具有中国特色的旅游系统模型,如有吴必虎提出的在 Gunn-Mill-Morrison 模型框架上合并交通和促销为出行子系统,增加支持子系统等。2000 年国家旅游局正式开通了国家旅游门户站点“中国旅游网”网站,同时筹建了旅游办公自动化。进入 21
8、世纪以后,我国旅游信息化开始了高速发展,包括旅游饭店、旅行社、旅游景区景点的信息化建设等都取得了一定的成绩。各大旅游资讯网站也如雨后春笋般涌现,不仅网易、新浪、搜狐、腾讯等这样的门户网站有旅游版块,而且还有许多像去哪儿、携程等这样的旅游电子商务网。 旅游系统最初几乎是在PC机上实现的 ,但是用户在旅游的时候需要随时了解景点的最新信息、发布最新动态以及使用定位功能等传统旅游系统无法满足的需求,鉴于目前移动平台使用的普及,在手机上使用旅游系统资源显然更适应发展。在Android手机上使用旅游系统,首先得开发一个基于Android的旅游软件安装包,这个软件需具有传统PC旅游系统的功能,由于它的载体手
9、机具有便携性,其优势也就凸显出来了。但是由于某些景点可能存在没有手机信号的情况,此时基于手机的旅游系统也就失去了意义。1.3本文主要工作 本文首先介绍了Android操作系统的四层架构及基于Android系统的应用程序开发方法。接下来以旅游系统的研发过程为例,详细阐述了开发Android系统应用程序的具体过程。结合实际情况,设计并开发一个基于Android平台的个人旅游系统,主要功能包括: 1)登陆功能:设置账号、密码登陆系统; 2)个人相册功能:查看、编辑、删除照片,并配以文字说明; 3)设置照片浏览功能,可以设置背景音乐; 4)考虑系统的功能扩充:每个模块可以独立运行使用,某些模块可以软件
10、化的部分软件产品,在硬件配置时,配置要合理,要尽量降低系统成本。2 Android系统简介2.1 Android系统概述 Android一词本意是指“机器人”,是Google公司推出的开源手机操作系统作为Google移动互联网战略的重要组成部分,Android操作系统借助于Google这个强大的推手和开放手机联盟的支持,由默默无闻变得备受瞩目,各种各样基于Android系统的设备相继问世。虽然Android系统从推出到现在不过短短几年时间,但作为移动终端设备操作系统中的重量级一员,它的影响力越来越大,吸引了越来越多的开发者、设备生产商和软件开发商等加入。作为一个推出不久的移动终端开发平台,为何
11、会有如此强大的发展潜力和如此迅猛的发展速度,每个人都会有自己的答案。总结起来,可能包括以下几点: 1)系统的开源性和免费性:Android系统是一个对第三方软件完全开放的平台,开发者在编写Android应用程序时具有更大的自由度。2)移动互联网的发展:Android采用WebKit浏览器引擎,与其它系统相比,更强调搜索功能,界面更强大,是一种融入全部Web应用的互联网络平台。3)相关厂商的大力支持:从组建开放手机联盟开始,Google一直向服务提供商、芯片厂商和手机销售商提供Android平台的技术支持,帮助他们开发出更好的Android设备。凡事都具有两面性,作为一个如此受欢迎的系统也不例外
12、。Android系统也有自身的一些缺点,具体如下:1)技术需要进一步完善:每个系统都不是完美的,Android也不例外,系统自身的一些bug需要进一步完善。尤其是Android系统作为一个开源的系统,面临的攻击会比其它封闭系统要多,这是Android系统要持续发展所必须解决的一个重要问题。2)开放手机联盟模式的挑战:Android由开放手机联盟开发、维护和完善,这种模式,是否会对Android未来的发展、定位起到阻碍作用,这些都不能下定论。3)其他技术的竞争:微软因为拥有PC操作系统市场最大的占有率,在未来手机与电脑互相联动并实现无缝对接方面Windows Mobile相比Android具有先
13、天优势,此外,即使在智能终端自身的操作系统上,iOS系统也是Android的一个劲敌。这些都给Android系统的进一步发展带来了巨大挑战,如果能很好的解决这些问题,也将会进一步促进系统的发展。2.2 Android系统架构Android系统采用了软件栈的设计结构,从上到下由四层组成,分别是Linux内核层、中间层、应用程序框架(Application Framework)和应用层(Applications)。如图2-1所示。图2-1 Android系统架构下面对每层进行具体的描述: (一)Linux内核:Android系统的内核在Linux2.6内核的基础上进行了相应的裁剪和改进,继承了Li
14、nux内核安全性、内存管理、进程管理、网络协议栈和驱动模型等。Linux内核同时也为硬件和软件之间提供了衔接,屏蔽了下层硬件的具体细节来为上层提供服务。 (二)Android函数库:Android包含一个能被不同组件使用的C/C+库,这些库通过Android应用程序框架来为上层应用程序提供服务,下面是一些常用的核心库: 1)libc:系统C库,从BSD发展而来的标准C函数库,是专门为基于嵌入式Linux设备所定制的。 2)媒体库:基于PacketVideo OpenCORE,支持多种常用的音频、视频格式回访和录制,同时支持静态图像文件。 3)Surface Manager:管理显示子系统,为多
15、个应用程序提供2D和3D图层的无缝融合。 4)SGL:底层的2D图形引擎。 5)3D libraries:基于OperGL ESI.OAPI实现,可以使用硬件3D加速或高度优化的软件3D加速。 6)RreeType:位图和矢量字体显示。 7)SQLite:一个对所有应用程序可用的、功能强大的轻量级关系型数据库引擎。 (三)Android运行时:Android运行时环境由一个核心库(Core Libraries)和一个D alvik虚拟机组成,核心库为上层应用程序编程提供了Java语言核心库的大多数功能。Dalvik虚拟机是一个不同于其他标准虚拟机的虚拟系统,采用寄存器架构,能在一个设备中同时高
16、效运行多个程序。它基于Linux内核的一些功能,如多线程机制和内存管理机制等。Dalvik虚拟机可以运行Android程序,这些程序需要使用dx工具转换成.dex类型的可执行文件,该格式文件在大小方面往往比同样的.class文件压缩成的.jar文件更小,可以降低对内存的要求。 (四)应用程序框架:包含编写核心应用所使用的API接口,开发者可以使用这些接口来编写自己的应用程序,该程序的架构设计简化了组件的重用,任何一个应用程序都可以发布它的功能块,同时还可以使用其他程序发布的功能块(但是要遵循安全限制)。每个应用都会包括一系列的服务和系统,具体如下: 1)丰富而又可扩展的视图:构建应用程序时可以
17、将这些视图进行各种组合来形成各式各样的应用程序界面。常用的视图包括:列表、网格、文本框、按钮和内嵌的浏览器等。 2)内容提供器:提供数据共享的途径,如联系人数据库。 3)资源管理器:管理非代码资源,如字符串、图片和布局文件等并提供这些资源的访问方式。 4)通知管理器:帮助应用程序在状态栏中显示各自的提示信息,如收到短信 5)活动管理器:管理应用程序的生命周期,还提供导航或回退功能等。 (五)应用程序:包括电话、短信、口历、地图、浏览器、通讯录等核心应用程序。2.3 Android开发环境配置 由于Java语言具有强大的功能和与平台无关的特性,并且还具备强制类型安全,因此Google选择使用Ja
18、va语言来开发Android系统下的应用程序。 Eclipse是一个开放源代码的、基于Java的且具有良好扩展性的开发平台。Eclipse本身只是一个框架和一组服务,但是通过加入插件可以构建针对不同语言的开发环境,目前支持的主要开发语言有Java和C/C+。基于以上优点选择使用Eclipse来搭建Android程序的开发环境并详细介绍环境的配置过程。搭建Android开发环境有以下五个主要步骤:下载并安装JDK;下载并安装Eclipse;下载Android SDK;下载并安装ADT插件;配置Android AVD。 1)下载并安装JDK; JDK是Java SE Development Kit
19、的简写,其中包括了Java运行环境、Java开发工具和一些Java核心类库等。在安装Eclipse之前,必须先下载和安装JDK。 JDK是由SUN公司开发,因此要下载最新的JDK,只要登录SUN公司的官网,选择适合自己电脑的版本下载并按照提示安装即可,如图2-2所示。图2-2 下载安装JDK JDK安装完成后,还得配置相应的环境变量才能使用。环境变量的配置分为两部分,一是JAVA HOME变量的配置,二是CLASSPATH变量的配置,这两者的配置方法类似。2)下载并安装Eclipse;进入http:/www.eclipse.org/downloads/页面,选择合适的Eclipse版本下载,如
20、图2-3所示。安装时注意选择合适的安装路径。图2-3 下载安装Eclipse 3)下载Android SDK;Android SDK是Android专用的软件开发包工具,包括程序开发中用到的函数库、编译程序等资源,是开发Android程序必备的工具之一。SDK的下载网址是http:/developer.A Location框中选择SDK的解压路径,点击Apply按钮,最后单击OK完成。如图2-4。图2-4 加载Android SDK4)下载并安装ADT插件; ADT是为方便Android应用而开发的插件,包含一系列强大的扩展功能,可以方便、快捷的创建、运行和调试Android程序。安装ADT的
21、步骤如下:首先,打开Elicpse,选择Windows-Preference-Help-Software Updates然后选择Available Software接着选择Add Sites,在弹出的地址框中输入http:/dl-5)配置Android AVD。 在Android SDK1.5版本以后的开发中,必须至少创建一个AVD来模拟一套虚拟设备运行Android应用程序。创建AVD有两种方式,一种是命令行方式,另一种是在Eclipse中创建,无论哪种方式,系统都会在默认文件路径下自动创建一个Android文件夹来保存与AVD有关的配置信息。这里只介绍在Eclipse中创建AVD的方法,步
22、骤如下:打开Eclipse,单机Android小机器人打开Android SDK and AVD Manager;点击左侧面板的Virtual Devices,再点击右侧的New;填入Name,选择Target的API, SD Card大小任意;点击Create AVD即可完成AVD的创建。如图2-5。图2-5 配置AVD2.4 Android程序开发2.4.1 程序开发组件 一个Android应用程序通常由以下五个组件中的任意多个组成:活动(Activity )、意图(Intent )、服务(Service)、广播接收器(Broadcast Receiver)和内容提供器(Content P
23、rovider)。 Activity负责应用程序的界面显示;Intent负责不同组件之间的交互;Service在后台运行,负责执行程序中比较费时的任务;而Content Provider为不同的应用程序之间提供了一种数据共享方式。其中Activity组件是每个应用程序所必须用到的,因为任何一个应用程序都必须具备与用户交互的界面。 (一)Activity:最基本的应用程序组件,通常表示为一个单独的屏幕。每个Activity都是通过继承来被实现为一个单独的活动类,一个应用程序通常由多个Activity组成,每个Activity都具有自己的生命周期。Android系统中通过一个被称为Activity
24、栈的东西来管理各个Activity之间的关系,当有新的Activity启动时,它被置于栈顶,之前的Activity被保留在栈中,不再出现在前台,直到当前的Activity退出为止。打开前一个 Activity可以通过回退来实现。Activity的生命周期如图2-6所示,主要有以下4种状态,分别是:1)活动状态,此时Activity处于栈顶位置并可以与用户交互,具有可见性。2)暂停状态,此时的Activity失去了焦点,但是依然保持可见状态(非全屏或是透明)并保存所有的信息,在内存过低时可能被“销毁”。3)停止状态,此时的Activity由于被其他Activity所遮挡而处于不可见状态,但是依然
25、会保存所有的信息,在系统内存过低时会被“销毁”。4)结束状态,此时的Activity已经被从内存中销毁,下一次启动时需要重置之前被保存的状态。图2-6 Activity的生命周期 从上图可以看出,Activity有以下三个循环过程:1)一个Activity的生命周期从onCreate(Bundle)开始,到onDestroy()结束,在onCreate()中会设置所有的状态和资源,在onDestroy()中回收这些资源,例如一个Activity中由于存在比较耗时的任务,会重新开启一个后台线程,这个线程可以在onCreate()中创建,在onDestroy()中停止。2)在onStart()到o
26、nStop()之间,Activity处于生命周期的前两个状态,此时无论该Activity是否能与用户交互,都具有可见性,可以保存相关的信息。3)从onResume()开始到onPause()结束,Activity处于活动状态,可以实现和用户的交互。Activity可以经常在resumed和paused状态之间切换,如当一个新的Intent被发送时。Activity的整个生命周期由以下几个函数定义,其中每个函数都可以重载。 public class Activity extends ApplicationContext protected void onCreate(Bundle savedln
27、stanceState); protected void onStart(); protected void onResume(); protected void onPause(); protected void onStop(); protected void onDestroy(); (二)Service:没有可视化的用户界面,在后台运行,通常用来完成比较耗时的工作,并且可以与其它程序进行交互。最典型的Service应用是在后台播放音乐或是从网络上下载数据。有两种不同的方式可以来启动一个Service,第一种方式是通过调用Context.startService()来启动,调用Conte
28、xt.stopService()来结束,这种方式无论调用了多少次startService()方法,都只需要调用一次stopService()方法来停止服务。第二种方式是建立一个到服务对象的链接,通过调用这个链接来获得服务。这个链接通过Context.bindService()方法建立,并通过调用Context.unbindService()方法来关闭。多个用户可以绑定至同一个服务提供对象。一个Service也具有一定的生命周期,如图2-7所示。图2-7 service的生命周期 从上图可以看出,service主要有以下两个循环过程: 1)完整的生命周期:从onCreate()开始到onDest
29、roy()结束,在onCreate()函数中完成初始化,在onDestroy()函数中释放所有的资源。例如一个音乐播放程序,可以在onCreate()中创建音乐播放线程,在onDestroy()中终止这个线程。 2)活跃的生命周期:从onStart()开始,在这个函数中处理传递给startService()的Intent对象。例如对于一个音乐播放程序,会在Intent中找到需要播放的音乐曲目。(三)BroadcastReceiver:用来接收广播信息,并给出相应的处理结果。这些广播信息也许来自于系统自身,如电池电量低、拍摄照片、来电话或短信等;也许来自应用程序,比如下载完成时发送通知来告知用户
30、。每个应用程序拥有的广播接收器没有限制,并且可以对任意感兴趣的通知进行响应,广播接收器也不具有用户界面。广播接收器的生命周期很短,只有在广播消息抵达接收器并且接收器中的onReceive()函数被调用时处于活跃状态,一旦onReceive()函数返回后,广播接收器就处于失活状态。(四)Intent:协助前面提到的三种组件完成通信过程,一个Intent由动作(Action)、数据(Data)、分类(Category)、类型(Type)、组件(Component)和扩展信息(Extra)等内容组成,系统根据Intent中所携带的不同描述信息来决定将此Intent交给哪个组件以及该组件获得Inten
31、t后要采取的动作。 (五)Content Provider:为应用程序之间共享数据提供了一个统一的接口并隐藏了具体的数据来源,Android系统中为一些常见的应用(如联系人、音乐、图像等)定义了相应的Content Provider,调用者通过相应的URI来对数据进行访问。通常Content Provider将一个应用程序的数据封装,并向需要使用该数据的其他应用程序赋予权限,这样就可以使得数据在多个程序之间共享。需要注意的是,Content Provider是基于权限控制的,这种做法可以提高数据的安全性。2.4.2 程序界面开发 Android系统为开发者提供了丰富的可视化界面设计组件,包括菜
32、单、对话框、按钮、文本框等,其中最主要的界面元素包括以下三类。 1)视图组件(View:是基类Android.view.View的一个实例,用来存储屏幕上特定矩形内的布局和内容属性,由视图又衍生出了一个子类Widgets(窗体控件),用来处理屏幕区域的测量和绘制,常用的Widget包括Text, EditText, Button,CheckBox和ScrollView等。2)视图容器(ViewGroup:是基类Android.view.ViewGroup的一个实例,用来承载和管理一组下层的视图和其他视图组,通常称为View的容器。3)布局管理:Android使用布局管理器来管理应用程序中各用户
33、界面的组件,这样做的好处是可以避免因手机分辨率、尺寸等的差异导致编写的应用程序无法移植,因为布局管理器能根据运行平台调整组件的大小。所有的布局管理器都是ViewGroup的子类,图2-8表示布局管理器中各类的关系。图2-8 Android布局管理器的类图 1)LinearLayout(线性布局):该布局中元素之间成线性排列,常用的布局有水平布局和垂直布局。 2)RelativeLayout(相对布局):该布局中元素之间根据相对位置排列,即在指定一个元素位置时往往会以它的父元素或其它元素的位置作为参照,来决定当前元素的位置,这种布局方式相对随意,没有规律性,但必须保证在使用之前其参照物己经存在。
34、 3)AbsoluteLayout(绝对布局):该布局中元素之间根据坐标排列,即将整个手机划分成坐标系,通过指定坐标系中的两个偏移量来决定元素的位置。 4)FrameLayout(帧布局):该布局为每个加入的组件都创建了一个空白区域(一帧),这些帧会根据gravity属性自动对齐,这样会形成组件叠加的效果。 5)TableLayout(表格布局):该布局中元素之间的排列由表格决定,表格的行和列通过添加TableRow或其他组件来控制,通常加入一个TableRow或是一个组件都代表一行,表格的宽度取决于父容器的宽度,这种布局只是实现方式与表格类似,但元素之间并没有实际的分界线。Android中提
35、供了两种方式来利用上面的组件设计布局,一是在XML布局文件中通过设置XML属性进行控制,二是在Java程序中通过调用函数进行控制,也可以将这两种方法组合起来使用。Android推荐使用XML布局文件的方式来控制用户界面的显示,这样做不仅简单明了,还可以将视图控制逻辑从代码中剥离出来,放入一个单独的文件中进行控制,更好的体现了MVC原则。2.5 Android系统数据存储方式 Android系统一共提供了四种数据存储方式,分别是SharedPreferences(通过键值二元组存储简单数据)、文件(存储较大规模的数据)、SQLite数据库(存储结构化数据)和ContentProvider(用于应
36、用程序之间的数据共享),下面详细介绍每一种方式的具体使用方法和使用场合。1) SharedPreferences:用键/键值形式的二元组来存储数据,支持的数据类型有Boolean, string, float, long和integer,通常用来存储默认值、实例变量、UI状态和用户设置等。每个应用程序Context均有一个SharedPreferences对象,通过getSharedPreferences()函数来获取该对象,通过getBoolean(), getFloat()和getInt()等函数读取该对象中存储的数据,这些函数一共有两个参数,第一个参数为键/键值对中的键,第二个参数为指定
37、键对应的键值,如果该键值不存在则以默认的函数返回值代替。修改SharedPreferences对象中的内容需要用到putBoolean() ,putFloat()和putInt()等函数,并且在修改完后还要调用commit()函数,否则修改无效。2)文件操作:Android上层应用程序是用Java语言编写的,在Java的I/O包中提供了大量的文件读写函数,如java.io.BufferedReader, java.io.FileInputStream, java.io.FileOutputStream等,Android对这些函数都有良好的支持,除此之外,Android还提供了openFileI
38、nput和openFileOutput这两个函数用来简化对文件的读写操作,与Java I/O包中的函数所不同的是,这两个函数只能操作当前应用程序所在目录的文件。3)SQLite数据库:SQLite是一种开源的、与底层无关的,轻量级的数据库,最大支持2048GB的数据存储,与其它大多数SQL数据库不同的是,SQLite没有独立的服务进程。SQLite中的数据库文件是跨平台的,可以在32位和64位系统之间,甚至Big-Endian和Little-Endian两种不同的架构之间自由的拷贝数据,SQLite数据库被用在大量的消费类电子产品中。SQLite数据库具有以下特点:1)无需配置:直接解压可执行
39、文件即可运行。2)没有服务进程:不需要提交到服务器处理后再返回结果。3)单个数据文件:将用户数据存储在一个文件中。4)数据文件可跨平台移植:不受操作系统位数和架构的限制。5)紧凑:不需要系统提供太大的资源,占用不到1M的内存空间就可运行。6)事务性:采用独立事物处理机制,遵守ACID (Atomicity, Consistency,Isolation, Durability)原则。使用数据库的独占性和共享锁处理事务,这样既允许多个进程并发读取数据库中的数据,又能保证最多只有一个进程写数据,可以有效地防止读脏数据、不可重复读、丢失修改等异常的发生。 3 SQLite数据库3.1 SQLite主要
40、语法3.1.1 结构新建SQLite数据库中的结构新建由以下四个部分组成:新建表:CREATE TABLE table_ name (column_ name1 data type, column_ name2 data type,),用来在SQLite数据库中新建一张数据表。新建视图:CREATE VIEWdatabase nameview name AS select statement,用来在SQLite数据库中新建一个视图(虚拟表),该表以另一种方式表示一个或多个表中的数据。新建触发器:CREATE TRIGGER trigger_name Database_eventON datab
41、ase_ nametable_ name Trigger_ action Database_ event: delete /insert /update /update of Trigger_ action:BEGIN select-statement/insert_ statement /update_ statement/delete_ statement END,用来在SQLite数据库中新建一个触发器,在用户试图对指定的表执行指定的数据修改语句时自动执行,其中触发器是一种特殊的存储过程。新建索引:CREATE INDEX index name ONdatabase nametable
42、name,用来为指定表或视图创建索引。3.1.2 结构删除 SQLite数据库中的结构删除由以下四部分组成: 1)删除表:DROP TABLEdatabase_nametable_name,用来删除数据表及该表的全部索引。 2)删除视图:DROP VIEW view_name,用来删除一个视图。 3)删除触发器:DROP TR工GGERdatabase_nametrigger_name,用来删除一个触发器。 4)删除索引:DROP INDEXdatabase_nameindex_name用来删除一个索引。3.1.3 数据操作SQLite数据库中的数据操作分为增加、删除、修改和查找四个部分,各个
43、操作的主要语法如下:增加:INSERT INTO table namecolumnl,column2,. VALUES (valuel,value2,.),向SQLite数据库的数据表中插入一行数据。删除:DELETE FROM table name WHERE column name=some value,删除SQLite数据表中符合条件的数据。修改:UPDATE table name SET colume name=new value WHERE column name=some value,将SQLite数据表中符合条件的记录修改为新的数据。查找:SELECT select list F
44、ROM table source WHERE search conditionGROUP BY group by_ expressionHAVING serch_ condition,查找SQLite数据表中符合条件的记录。3.1.4 事务处理当有多项相关的操作需要完成时,可以使用SQLite数据库提供的事务处理机制,即使用多条SQL语句结合在一起形成一个逻辑处理单元,其中每条语句都只能完成整个任务中的一部分,所有语句合起来才能完成全部任务。SQLite数据库保证事务处理过程中的所有操作要么全部完成,要么回到起始状态,这就是事务处理的原子性。事务处理还具有其他三条属性,分别是一致性,隔离性和永
45、久性一致性是指当事务完成时,数据必须处于一致状态;隔离性是指对数据进行修改的所有并发事务是彼此隔离的,即一个事物不应以任何方式依赖或影响其他事务;永久性是指当事务完成后,它对数据库的修改被永久保存。这四条属性结合起来可以确保使用事务处理机制对SQLite数据库的修改不会给数据库带来“脏数据夕事务处理机制可以划分为事务开始、事务终止、事务结束和事务回滚四部分,各部分的语法如下所示:事务开始:BEGIN TRAN SACTION name 事务终止:END TRAN SACTION name 事务结束:COMMITTRANSACTIONname事务回滚:ROLLBACKTRANSACTIONnam
46、e3.2 SQLite内置函数 SQLite数据库中内置了大量的基础函数供用户使用,这些函数可以分为算术函数、字符串处理函数、条件判断函数、集合函数以及其它函数共五大类,下面列举一些常用函数。 1)算术函数: abs(X):返回给定数字表达式的绝对值 max(X,Y,. . . . . . ):返回给定表达式的最大值。 min (X,Y,.):返回给定表达式的最小值。 random():返回随机数。round(X, Y):返回数字表达式并四舍五入为指定的长度或精度。2)字符串处理函数: length(X):返回给定字符串表达式的字符个数。 lower(X):将大写字符数据装换为小写字符数据后返回字符表达式。 upper(X):将小写字符数据装换为大写字符数据后返回字符表达式。 substr(X,Y,Z):返回字符串表达式中的一个子串。 randstrU随机产生一个字符串。 like(X,Y):判断给出的字符串是否与指定模式匹配。