数字城市查询系统设计及数据库设计毕业论文.doc
《数字城市查询系统设计及数据库设计毕业论文.doc》由会员分享,可在线阅读,更多相关《数字城市查询系统设计及数据库设计毕业论文.doc(47页珍藏版)》请在三一办公上搜索。
1、数字城市查询系统设计及数据库设计摘要本设计以EmbestS3CEB2410(ARM9)开发板为硬件底层,在Linux操作系统平台的基础上,利用开源Qt图形用户应用程序框架,基于SQLite数据库,开发出软硬件一体化的便携式嵌入式电子地图,功能包括数字建筑物的查询,以及相关公交系统查询的地图信息查询系统。本系统具有可扩展性好,实用性强、可移动的特点,易于移植到不同的硬件平台和其他操作系统软件环境。关键词:EmbestS3CEB2410(arm9) , SQLite , qt ,Linux Digital City for System Design and Database DesignABST
2、RACTThe design take EmbestS3CEB2410(ARM9) development board as the hardware first floor, in the Linux operating system platforms foundation, uses the source Qt graph user application procedure frame, based on the SQLite database, develop the software and hardware integration the portable embedded el
3、ectronic map, the function including the digital buildings inquiry, as well as related public transportation system inquiry map information referral system. This system has the specialty such as the extendibility to be good, usability strong, transportable characteristic, easy to transplant to the d
4、ifferent hardware platform and other operating system software environment.Key words:rEmbestS3CEB2410(arm9), SQLite, qt,Linux目录目录41引言51.1项目简要介绍51.2项目背景51.3项目的创新点61.4相关技术71.4.1基于ARM处理器的硬件开发平台71.4.2嵌入式数据库81.4.3嵌入式操作系统91.4.4Qt开发语言101.5定义122系统需求分析122.1系统需求122.2开发环境132.2.1硬件平台132.2.2软件开发平台132.2.3开发语言132.
5、3运行环境133系统概要设计143.1总体设计143.2系统数据流图154系统数据库设计164.1数据表165系统详细设计175.1功能模块划分175.2核心算法描述186SQLITE数据库配置196.1SQLite下载196.2安装SQLite196.3测试数据库197部分功能代码207.1数据库操作模块代码207.2请求响应模块的函数集合217.3显示相关信息功能模块函数集合238参考资料319致谢3110附录311 引言1.1 项目简要介绍随着时代的进步,人们的活动领域不断地扩大,地理环境的不熟悉程度越来越大,人们迫切需要有一种方便快捷的地理信息查询工具。本项目的目的在于开发出价格更低廉
6、、功能更实用、可移动性强、运行速度更快更稳定、软件移植性好、界面友好的电子地图信息查询系统嵌入作品,方便广大的用户,给用户最实用的功能。项目是以EmbestS3CEB2410(arm9)开发板为硬件底层,是以Linux为操作系统,是以SQLite为数据库,是以C+为开发语言,是以Qt来支撑C+图形用户界面应用程序框架。最终开发出软硬件一体化的地图信息查询系统。本系统具有实用性强、可移动性好的等特点。本项目就是为了满足广大用户的需要具有在陌生的环境下寻找各个地点,并快速察看目的地的地理位置,查询到达目的地的行走路线。使用户处在一个陌生的环境里不会迷失方向。1.2 项目背景在当前数字信息技术和网络
7、技术高速发展的后PC(Post-PC)时代,嵌入式系统已经广泛地渗透到科学研究、工程设计、军事技术、各类产业和商业文化艺术以及人们的日常生活等方方面面中。随着国内外各种嵌入式产品的进一步开发和推广,嵌入式技术越来越和人们的生活紧密结合。Linux从1991年问世到现在,短短的十几年时间已经发展成为功能强大、设计完善的操作系统之一;越来越多的企业和研发机构都转向嵌入式Linux的开发和研究上,在新兴的嵌入式操作系统领域内也获得了飞速发展。地图已成为人们日常工作、学习、旅行经常利用的工具!一张普通地图综合反映地面上物体和现象一般特征的地图,内容包括各种自然地理要素(地形、水系、植被等)和社会经济要
8、素(居民点、行政区划、交通线路等)。从古至今,人们已经形成一个意识:地图用来查找地理位置。生活中常常会遇到这样一个问题:不知道想要去的目的地具体在什么地方,即问路问题。在以前,人们一般有两种解决方法。1、去问人;2、查找地图。第一种方式,实际效果并不是很理想;在大城市中,如广州,即使一个长年居住在那里的人也不能对该城市每一个地方都清楚;如果知道那个地方,未必能表述清楚,无法在询问者脑海中产生空间感、方位感。可见这种方式解决给问题,效果很一般。但是在目标地区附近询问他人,关于目标位置却是十分可行的办法之一!第二种方式,效果较好,但是很难提高查找效率;读者会有这一个理性的认识:地图上所含的信息内容
9、多,要在地图上找到需要的信息,并非易事。尤其是找一些中小企业公司和后街小巷。在地图上这样相似信息多如牛毛。一般需要几分钟到几十分钟,甚至上一个小时来看地图,找地方。可见两种传统的解决方式都有诸多不便之处!随着计算机电子技术的飞速发展,现在为上述问题提供了更方便的解决方式-电子地图。电子地图的应用从上个世纪九十年代初就已经开始,那个时候的电子地图大多被企业内部所应用,随着它与网络的逐步结合,开始被诸多大众所接受和使用。2004年年终GOOGLE推出了电子地图的服务,2005年电子地图与搜索引擎的紧密接触,对电子地图的发展产生了巨大的推动作用,受众群体产生了巨大变化。从单纯的通过网站查询地图位置,
10、到手机、车载GPS等各种导航定位服务,电子地图与各种终端结合所产生的巨大价值,使其成为数字时代的新热点而被广泛关注起来。我们可以相信未来对电子地图的应用将更为普及。目前市面上使用的电子地图基于网站查询地图位置,手机、车载GPS等服务和产品。这些服务和产品对人们提供了不少的便利是毋庸置疑的。每一种方式都有其优点和局限性。n 网站查询地图位置。网络依赖性强,没有网络的支持无法服务,查询结果返回的快慢很大程度与网速有关;如果用个人pc机位查询终端,可移动性差、成本高。一般人只能在固定地点使用电脑查询地图,如果出门在外,这种方式不可行。优点:查询速度快。n 手机GPS产品。价格昂贵,手机产品能支持该功
11、能或平台的售价至少要1500元以上;手机GPS功能的开通或使用也需要一笔费用。网络依赖性强,如果没有网络的支持,功能无法实现。查询速度慢,手机GPS必须通过无线网络进行通信,数据通过网络传输必定有时延,也会占用嵌入式系统有限的资源。软件的可移植性差,其软件产品只能在手机平台上使用。优点:可移动性。n 车载GPS产品。价格昂贵,产品售价一般2000元以上。网络依赖性强,如果没有网络的支持,功能无法实现。查询速度慢,车载GPS同样也必须通过无线网络进行通信,数据通过网络传输必定有时延,也会占用嵌入式系统有限的资源。优点:可移动性、软件可移植性我们的项目正是为了改进上面所提出不足的。该项目的目的在于
12、开发出价格更低廉、功能更实用、可移动性强、无网络依赖性、运行速度更快更稳定、软件移植性好、界面友好的作品,方便广大的用户,给用户最实用的功能。1.3 项目的创新点l 软硬件相结合,软硬件一体化,可移动性好;l 信息集成化,把最实用的功能集成到一起,地图搜索、公交查询、建筑介绍(历史、用途、娱乐服务内容、特色饮食、联系方式、营业时间、火车汽车轮船客货运输线路班次等);l 有输入检测功能,有含糊查询功能;l 查询速度快,有显示所需查询时间;l 查询结果立体形象,图文相结合。既有地图标示、划线,也有文字信息;l 具有声音提示功能,查询结果更形象立体;l 人性化的人机交互界面,采用人们习惯的界面风格(
13、goolge地图界面风格),界面简单,符合用户使用的习惯,易上手便使用的特点。l 软件相对独立性,软件系统可移植在多个硬件平台如:手机、mp4、个人pc机等,和多个软件平台上运行如: Windows、Linux和Unix系统软件上使用1.4 相关技术1.4.1 基于ARM处理器的硬件开发平台为一种16/32位的高性能、低成本、低功耗的嵌入式RISC微处理器,ARM微处理器目前已经成为应用最为广泛的嵌入式微处理器。ARM技术还将不断发展。在嵌入式领域,ARM已取得了极大的成功,造就了IP核商业化、市场化的神话,迄今为止,还没有任何商业化的IP核交易和使用达到ARM的规模。ARM系列芯片已经被广泛
14、的应用于移动电话、手持式计算机以及各种各样的嵌入式应用领域,成为世界上销量最大的32位微处理器。ARM9系列处理器是英国ARM公司设计的主流嵌入式处理器,主要包括ARM9TDMI和ARM9E-S等系列。新一代的ARM9处理器,通过全新的设计,采用了更多的晶体管,能够达到两倍以上于ARM7处理器的处理能力。这种处理能力的提高是通过增加时钟频率和减少指令执行周期实现的。ARM7处理器采用3级流水线,而ARM9采用5级流水线。增加的流水线设计提高了时钟频率和并行处理能力。5级流水线能够将每一个指令处理分配到5个时钟周期内,在每一个时钟周期内同时有5个指令在执行。在同样的加工工艺下,ARM9 TDMI
15、处理器的时钟频率是ARM7TDMI的1822倍。ARM9系列微最适合用于对价位和功耗要求较高的消费类应用。ARM9微处理器系列具有如下特点:1) 32bit定点RISC处理器,改进型ARMThumb代码交织,增强性乘法器设计。支持实时(real-time)调试;2) 片内指令和数据SRAM,而且指令和数据的存储器容量可调;3) 片内指令和数据高速缓冲器(cache)容量从4K字节到1M字节;4) 设置保护单元(protcction unit),非常适合嵌入式应用中对存储器进行分段和保护;5) 采用AMBA AHB总线接口,为外设提供统一的地址和数据总线;6) 支持外部协处理器,指令和数据总线有
16、简单的握手信令支持;7) 支持标准基本逻辑单元扫描测试方法学,而且支持BIST(built-in-self-test);8) 支持嵌入式跟踪宏单元,支持实时跟踪指令和数据。ARM9系列微处理器的主要应用领域为:无线网络设备、PDA功能、移动电话等多种多媒体和嵌入式应用.ARM9系列微处理器包括如下几种类型的核:ARM9TDMI,ARM920T,ARM940T,ARM9E-S。如何选择开发平台(主要是指CPU和操作系统以及开发环境和工具)也是一个比较重要的问题,有时这不但影响进度,产品质量,可维护性等一般问题,甚至涉及到方案的可实现性。下面大概列出一些需要考虑的问题:从系统功能实现考虑: (1)
17、 是否有开发板配套的软件模块直接实现系统功能要求,包括驱动。 (2) 价格。准确的说应该是性价比,这要跟项目的需求与开发板提供的功能进行对比,确定是否会有太多功能不项目需求不需要的,因为功能多的开发板自然价格也就贵了。 (3) 功耗。如果功耗太高,对移动设备而言,这一点可是致命的。 (4) 处理速度。关系到CPU指令周期,有没有流水,有没有并行,体系结构,有没有专用指令,对外部存储器和外设的存取速度等等。 (5) 外设硬件是否满足项目需求。从开发者的角度考虑: (1) 是否有足够的技术支持包括测试开发工具等。 (2) 相关资源是否丰富。包括网上资源、书籍,第三方提供的工具帮助等。系统的可移植性
18、和可扩展性。1.4.2 嵌入式数据库什么是嵌入式数据库通常我们采用数据库来实现对数据的存储检索等功能,像MySQL这类基于C/S结构的关系型数据库系统虽然代表着目前数据库应用的主流,却并不能满足所有应用场合的需要。很多的应用仅仅利用到了这些数据库产品的基本特性而已。有时我们需要的可能只是一个简单的基于磁盘文件的数据库系统。这样就不必安装庞大的数据库服务器以简化数据库应用程序的设计,在某些特殊应用场合,比如在嵌入式系统中,由于系统的硬件软件资源都有限,这些数据库产品就明显有一些臃肿甚至是不可实现的。在这些情况下嵌入式数据库的优势就特别明显了。嵌入式数据库的名称来自其独特的运行模式。这种数据库嵌入
19、到了应用程序进程中,消除了与客户机服务器配置相关的开销。嵌入式数据库实际上是轻量级的,在运行时,它们需要较少的内存。它们是使用精简代码编写的,对于嵌入式设备,其速度更快,效果更理想。嵌入式运行模式允许嵌入式数据库通过 SQL 来轻松管理应用程序数据,而不依靠原始的文本文件。典型嵌入式数据库比较目前,基于嵌入式数据库应用的市场需求已经进入加速发展的阶段,适用于嵌入式开发的嵌入式数据库主要有mSQL、Berkeley DB、SQLite等。 (1) Berkeley DBBerkeley DB是一个开放源代码的嵌入式数据库管理系统,为许多编程语言提供了实用的API接口,包括C、C+、Java、Pe
20、rl、Tcl、Python和 PHP等。它通过调用这些API来完成对数据的保存、查询、修改和删除等操作,能够用来管理多达256TB的数据,并且在许多方面的性能还能够同商业级的 数据库系统相抗衡。Berkeley DB能够很轻松地应付几千个用户同时访问同一个数据库的情况。 另外,由于其应用程序和数据库管理系统运行在相同的进程空间当中,进行数据操作时可以避免繁琐的进程间通信,因此耗费在通信上的开销自然也就降低到了极低 程度。但是Berkeley DB不是关系型的数据库,不能应用标准的SQL语句对数据库操作,缺少灵活性,而且学习起来有一定难度,必然会加大开发成本。(2) mSQLmSQL是一种简化的
21、SQL数据库,体系结构小巧,占用系统资源少,特别适合在嵌入式Linux系统中使用。同时,mSQL提供专门的API函数,使得用C语言编写的CGI程序可以与mSQL的数据库引擎进行通信。但它只有30天的使用期限,并非完全的开源。(3) SQLiteSQLite 是 D. Richard Hipp 用 C 语言编写的开源嵌入式数据库,是同类产品中的后起之秀,2005年获得了开源大奖。SQLite可以在所有主要的操作系统上运行,并且支持大多数计算机语 言。SQLite 还非常健壮。其创建者保守地估计 SQLite 可以处理每天负担多达 100,00 次点击率的 Web 站点,并且 SQLite 有时候
22、可以处理 10 倍于上述数字的负载。SQLite采用单文件存放数据库,速度又比 MySQL 快上 12 倍,存储量也不是问题,在操作语句上更类似关系型数据库的使用,使用操作非常方便。其主要的特点:1. 支持多数 SQL92 标准2. ACID事务支持,甚至在数据库崩溃和恢复时也支持3. 零配置无需安装和管理4. 整个数据库存储在单个文件中5. 支持数据库大小至2TB6. 足够小,大致3万行C代码,250K二进制目标代码7. 大部分普通数据库操比一些流行的数据库还要快8. 提供简单、易用、多种语言的API9. 完全独立的,不具有外部依赖性10. 作为一款嵌入式数据库,SQLite与Berkely
23、 DB一样,以库的形式提供,通过C函数直接操作数据库文件(也支持其他的访问方式,比如Tcl)SQLite不是Server,所以和SQLServer等不同,它和程序运行在同一进程,中间没有进程间通信,速度很快,而且体积小巧,易于分发,非常适合运行在单机环境和嵌入式环境。与Berkely DB相比, SQLite功能虽较Berkeley DB略有逊色,但在开源组织的推动下差距正在缩小。实际上,很多情况,特别是在嵌入式系统应用中,并不需要存储过程或复杂的表之间的关联,这时会发现 SQLite在大小和功能之间找到了一个理想的平衡点。其次SQLite是关系型数据库,支持大部分SQL语句,这是它比Berk
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数字 城市 查询 系统 设计 数据库 毕业论文
链接地址:https://www.31ppt.com/p-3944181.html