空间数据库的第四章讲.ppt
《空间数据库的第四章讲.ppt》由会员分享,可在线阅读,更多相关《空间数据库的第四章讲.ppt(76页珍藏版)》请在三一办公上搜索。
1、面向对象空间数据模型,Back,一、面向对象的概念与模型二、面向对象的空间要素模型三、面向对象的 几何对象模型四、空间数据库的纯关系实现 五、空间数据库的对象关系实现,面向对象的概念(核心概念),一、核心概念(一)对象(Object)现实世界中的各类现象抽象表示成具有不同特征的对象。对象是具有状态和行为特征的实体,对象之间相互区分、相互联系。对象的标识、属性和方法是它的三个关键成分。1、对象标识:为每个对象在全系统范围内定义唯一标识(OID-Object Identifier),在其生命周期中保持不变,是确定对象存取的唯一方法。2、对象属性:对象的状态通过属性变量定义,由属性值描述。属性变量定
2、义属性的型,包括属性名称、数据类型、取值范围和语义完整性约束。每个对象具有一到多个属性,所有属性值共同描述其状态。3、对象方法:表示对象状态的属性值由一组函数来操作和维护,这些函数称为方法。属性的型是事先定义的,属性值由方法来获取和改变。,面向对象的概念(核心概念),(二)消息(Message)对象的属性只能通过对象自己的方法来获取和改变。消息是对象间交互的手段,一个对象要获取或改变另外一个对象的属性,只能通过消息引用被访问对象提供给外界的方法来实现。(三)协议(Protocol)协议是一个对象所能接受的所有消息构成的集合,是对象的对外接口,是被访问对象提供给其他对象使用的所有方法的集合。(四
3、)封装(EncapsuIation)和消息传递 对象、消息和协议打包在一起叫封装。将属性和方法封装在对象中,向对象发送消息,通过对象所指定的公共接口来存取、维护属性,这是访问对象属性的唯一方法。封装的意义在于对象的访问只能按对象提供给外界的协议接口进行,只能通过协议中提供的方法向对象发送消息。,面向对象的概念(核心概念),(五)类和实例(CIass、Instance)类是对具有共同特征的一组对象的抽象,具有相同的属性类型、消息接口和方法定义的所有对象构成一个类。类中的一个具体对象称为其所属类的一个实例,每个实例具有各自不同的状态(属性值)。类有三种主要类型:1、抽象类(AbstractClas
4、s):不能创建对象,只能作为父类。2、伴随类(CoClass):可创建类。可直接创建新对象或实例化。3、类(Class):可实例化类。不能直接创建新对象,但在其他类的属性中可创建它的对象,可以被另一个类的对象实例化,可以被其他类引用,是一种元件类或成份类。,图4-1 类与联系,面向对象的概念(核心概念),(六)类的描述 类的定义称为类的描述(对象的型或模式),包括协议描述和实现描述两个方面。协议描述定义了该类实例的消息接口(协议中所有消息),实现描述包括属性变量的定义及所有方法的实现方式描述。(七)继承与类等级(Inheritance、CIass Hierarchy)类等级结构表达了超类(或父
5、类、基类)与子类间的继承关系,类等级的继承性使得子类能自动地继承其超类的全部语义特性(属性、方法、约束)。多层类的继承具有传递性,下层子类可继承其上部各层超类的全部语义特性,即父类的所有属性和方法可以被它的所有子类传递地继承。子类还可以附加新的属性和方法,一个实例是其所有超类的一个逻辑上的实例。,面向对象的概念(核心概念),(八)功能重载和多态性(0verLoading、PoIymphism)子类对超类方法的覆盖功能就是重载与多态的体现。子类定义的新方法与继承父类的旧方法可具有相同的名称、形式参数和返回值,也可以同名但具有不同的形式。系统调用时根据不同的描述信息,选择合适的方法运行。通常把同一
6、个类中有多个同名方法的现象称为重载或多态,消息传递的实现是以重载和多态为支撑。(九)类图 类图是一种框架(Frame)、模板(Template)或模式(Schema),描述同类对象的特征及多个类之间的联系。(十)实例图 实例(对象)图是类图的具体实现,给定一张类图必对应实例图的一个无限集合。,面向对象的概念(核心概念),(十一)链接与联系(Llnk、Association)链接与联系是建立对象之间及类之间关系的一种手段。两类之间的直线表示联系,两对象之间的直线表示链接。联系主要有下列三种:1、实例化(Instantiation):一个类中有一个方法可创建另一个类的对象。2、聚集或聚合(Aggr
7、egation 和 Composition):聚集表示“部分与整体”的关系,由元件(Components)对象构造复杂组合(Assembly)对象。主类控制着成分类的生命周期。3、联合(Association):除去类等级关系和类组成关系以外,还有一些类之间的对应关系称为联合。如:材料与产品的关系,学生与课程的关系等。(十二)一般化和特殊化(Generalization、Specification)一般化指从一组相似的对象中找出共性,子类的共性归入父类,产生祖先类与后代类之间的类等级和类结构关系。特殊化是在一般类共性的基础上扩展特性构成新的具体类,子类可继承父类的性质,可对父类的属性和方法进行
8、更新,也可添加自身特定的属性及方法。,面向对象的概念(扩充概念),二、扩充概念复合对象与类复合等级 如果对象的一个属性的定义域不是基本类(整数、字符串等),而是另一个非基本类(一个类等级结构),对应的属性值为这个非基本类的类等级结构中任意一个类的一个实例,属性取值为该对象的标识符(一个对象引用其他对象),这个对象称为复合对象。复合对象是构成一个整体与部分等级的非匀质对象集合,它将“整体与部分”的关系补充到一个对象与其引用的其他对象之间的聚集关系中。面向对象表达方式中,空间要素的主题属性在一个基本类(整数或字符串)的范围内取值,而空间属性的定义域则为一个非基本类,空间属性取值为非基本类的类等级中
9、某个对象(几何对象)的主关键字或对象标识,称为空间要素对一个几何对象的引用。对象的引用建立了一个对象和引用它的另一个对象之间的“整体与部分”关系,通过属性对其他类的引用构成嵌套关系模型,称为类复合等级(a class composition hierachy)。,Back,面向对象数据模型,一、对象与封装性(encapsulation)每个概念实体模型化为一个对象,一个对象由描述该对象状态的一组属性数据和表达其行为的一组方法组成,是属性数据和行为的统一体。一个对象object可定义成一个三元组:object=(ID,S,M)其中,ID为对象标识,M为方法集,S为对象的属性数据集合,它可以是一个
10、属性值,也可以是另外一组对象的集合,明显地表现出对象的递归。,面向对象数据模型,二、分类(classification)类是同类对象的集合,类将具有相同属性和方法的对象组合在一起。属于同一类的所有对象具有相同的属性定义(数据类型和取值范围)和方法定义(函数体)。用一个三元组来描述类:class=(CID,CS,CM)其中,CID为类标识,CS为类的状态描述,CM为该类的方法。显然有:S CS和M CM 当object class,面向对象数据模型,三、概括(generalization)将多个类中的公共属性和方法抽象出来形成一种更一般的超类。设有两个类:class1=(CID1,CS1,CM1
11、)=(CID1,CSA,CSB,CMA,CMB)class2=(CID2,CS2,CM2)=(CID2,CSA,CSC,CMA,CMC)class1和class2中都带有相同的属性子集CSA和方法子集CMA。并且:CSA CS1和CSA CS2 以及CMA CM1和CMA CM2。将共同属性和方法提取出来形成一种超类,SID为超类的标识符。Superclass=(SID,CSA,CMA)定义超类后class1和class2称为Superclass的子类,分别表示为:class1=(CID1,CSB,CMB)class2=(CID2,CSC,CMC),面向对象数据模型,超类与子类之间的继承与抽象
12、关系构成一种类等级结构,空间数据库中限定每个子类只能有一个父类,但可以有多个子类。子类可从父类继承属性和方法,也可定义自身特有的属性和方法。图4-2为一个简单的层次模型,表示了路类、公路类、路段类之间的类等级关系。公路类是路类的子类,路段类是公路类的子类。公路类继承了路类的属性,并增加了等级、路面、宽度等属性。路段类除了继承公路类的属性外,又新定义了起点、终点等自己的属性。,图4-2 空间类的类等级结构,面向对象数据模型,四、聚集(aggregation)聚集将几个不同特征的对象组合成一个更高水平的复合对象,每个不同特征的对象是该复合对象的一部分,它们有自己的属性数据和方法,这些属性数据和方法
13、不能为复合对象所公用,但复合对象可以从中派生得到一些信息。例如,弧段聚集成线状地物或面状地物,简单地物组成复杂地物。设有两种不同特征的元件对象:object1=(ID1,S1,M1)object2=(ID2,S2,M2)用它们组成一个新的复合对象:object3=(ID3,S3,Object1(Su),Object2(Sv)M3)其中Su S1,Sv S2,从式中可见,复合对象object3拥有自己的属性值和操作,它仅从分子对象中提取部分属性值,且一般不继承子对象的方法。,面向对象数据模型,一个空间类(非基本类)的实例可以作为元件类实例,聚合成另一个不同类型空间类的实例。聚合与引用关系表达了类
14、与类之间的横向构成关系,构成了空间数据库的类复合等级结构。一个复杂的空间对象由多个其他的空间对象组成,如交通网络由交叉路口、服务设施、道路等组成。图4-3为复合引用与弱引用举例:,图4-3 空间类的类复合等级结构,面向对象数据模型,五、联合(association)类等级和类复合等级关系是空间类之间的两个最主要关系,除此之外实例间还存在一些其他联系,如共存时间段、联合关系等。在定义对象时,将同一类对象中的几个具有相同属性值的对象组合起来,为了避免重复,设立一个更高水平的对象表示那些相同的属性值。假设有两个对象具有一部分相同的属性值:object1=(ID1,SA,SB,M)object1=(I
15、D2,SA,SC,M)可设立新对象object包含object1和object2,object3=(ID3,SA,object1,object2,M)此时,object1和object2可表示成:object1=(ID1,SB,M)object2=(ID2,SC,M)object1和object2称为“成分对象”,它们的联合所得到的对象为“组合对象”。联合的一个特征是它的成分对象应属于同一个类,即object1和object2是同一个类的对象。,Back,面向对象空间数据模型(应用问题描述),一、数据 应用涉及行政区划、城市间路网和土地使用三类数据。抽象为七个专题:(一)行政区划 行政区域的层
16、次结构划分为国家、省和县三层。抽象为三个专题:1、国家country(国家名name,几何属性geometry)2、省province(省名name,几何属性geometry)3、县county(县名name,人口population,几何属性geometry),面向对象空间数据模型(应用问题描述),(二)城市间的路网 城市间的路网包含道路、路段、城市。抽象为三个专题:1、道路highway)(道路名称,道路类型)2、路段section(路段名称,车道数,几何属性geometry)3、城市city(城市名称,人口,几何属性geometry)(三)土地使用 土地使用(land use)专题中每个
17、要素有一种土地使用类型,如居住区、森林、农田等。,面向对象空间数据模型(实现的功能),二、实现的功能(一)查询分类 1、属性查询(alphanumeric criteria):查询条件中只含主题属性。2、空间查询(spatial criteria):查询条件中含有几何对象和空间操作。3、交互式查询(interactive):人机交互式查询。(二)查询命名 查询名称=类型前缀+模式前缀+编号。类型前缀:属性查询ALPHA-、空间查询SPAT-、交互式查询INTER-。模式前缀:行政区划ADM、路网R、土地使用LU。编号:类型前缀和模式前缀相同时查询的编号。例子:ALPHA-ADM2表示在行政区模
18、式上的第二个属性查询。,面向对象空间数据模型(实现的功能),(三)查询定义 1、属性查询:ALPHA-ADM1:某省某县的居民数量。ALPHA-ADM2:某省有多少个县。ALPHA-ADM3:中国的居民数量。ALPHA-R1:某一条道路第一路段的车道数。ALPHA-R2:某一条道路的所有路段名。,面向对象空间数据模型(实现的功能),2、空间查询:SPAT-ADM4:与某省相邻的省。SPAT-ADM5:显示某个省。SPAT-ADM6:全国范围内,大于“某省”中最大一个县的那些县。SPAT-R3:某条道路的长度。SPAT-ADM-R1:通过某个省的所有公路。SPAT-ADM-LU1:显示某个县的所
19、有居住面积。SPAT-ADM-LU2:行政区域与土地使用专题的覆盖。3、交互式查询:INTER-ADM7:在屏幕上点击选择一个县。INTER-ADM8:含在所选窗口中的省。INTER-ADM9:用给定窗口裁剪出的县。INTER-R5:在屏幕上点击,选中一条道路的路段。INTER-R6:所选路段对应的道路是哪几条。,面向对象空间数据模型(概念模型),一个专题对应一个空间要素类,用矩形方框表示。两个类之间的连线表示类之间的联系,表示聚合关系,表示一对多联系。一、行政区划(Schema 1)图4-4定义国家、省、县三个专题模式及相互间的聚合关系和一对多联系。,面向对象空间数据模型(概念模型),二、城
20、市间的路网(Schema 2)图4-5定义了道路、路段、城市三个专题模式及相互间的聚合关系和一对多联系。一条道路由多个路段组成,一个路段属于多条道路,道路与路段是多对多关系。一条路段连接两个城市,路段有方向,一个城市被多条路段连接,道路和城市也是多对多关系。,面向对象空间数据模型(概念模型),三、土地使用(Schema 3)土地使用(land use)专题模式的定义如图4-6所示。,面向对象空间数据模型(扩展E-R图表达的概念模型),一、扩展E-R模型的概念 象形图定义一种图形符号,形式为方框内包含一个对象表示符。将图形符号放在实体矩形框中适当的位置,表示实体的几何特征。任何两个空间实体间都隐
21、含着空间联系,可定义表示空间联系的象形符号。,图4-7 扩展E-R图模型中的象形图符号,面向对象空间数据模型(扩展E-R图表达的概念模型),二、空间要素概念模型(一)行政区划(Schema 1),图4-8 行政区划的扩展E-R图,面向对象空间数据模型(扩展E-R图表达的概念模型),(二)城市间路网,Back,图4-9城市间路网的扩展E-R图,(三)土地使用,图4-10土地使用的扩展E-R图,几何对象模型(几何类层次结构),面向对象空间数据模型用一组基本空间数据类型来满足常用几何形状的建模需求,表示几何对象的属性、方法和关系。图4-11是OpenGIS Simple Features Speci
22、fication For SQL92和SQL99中定义的几何类层次模型,表示基本空间几何体及其关系。其中划分了几何类型,定义了每个几何类的属性和方法,描述了几何类等级和几何类复合等级结构。,图4-11 几何对象层次结构,几何对象模型(几何类层次结构),一、类等级结构 1、几何体Geometry是一个不能实例化的抽象类,它是所有基本几何体的超类,它定义了所有基本几何体的共同属性和方法。2、空间参照系统类与几何体Geometry类之间存在着一对多的关系,即所有的基本几何体必须选择相同的空间参照系统。3、几何体Geometry有四个子类,分别是点Point、曲线Curve、面Surface和几何体集
23、合Geometry Collection。4、几何体集合Geometry Collection有点集合MultiPoint、曲线集合MultiCurve和面集合MultiSurface三个子类。,几何对象模型(几何类层次结构),5、曲线Curve的子类是用直线连接各点形成的线串LineString。6、面Surface的子类是多边形Polygon。7、曲线集合MultiCurve的子类是线串集合LineStrings。8、面集合MultiSurface的子类是多边形集合Polygons。9、线串LineString的子类是线Line和线环LinearRing。每个子类都继承了父类的所有语义特征
24、,并可以定义子类新的属性和方法。,几何对象模型(几何类层次结构),二、类复合等级与联系 1、一个线串LineString对应多个点Point,一个点集合MultiPoint也对应多个点Point。2、一个多边形Polygon对应1多个线环LinearRing。3、一个线串集合LineStrings对应多个线串LineString。4、一个多边形集合Polygons对应多个多边形Polygon。具体应用中还可以对图4-11中表示的几何类层次结构进行扩展。如为几何体集合Geometry Collection定义一个子类,该子类是由点集合Points、线串集合LineStrings和多边形集合Pol
25、ygons构成的复杂几何对象。也可以为曲线Curve定义一个子类,即用曲线连接各点形成的弧。,几何对象模型(几何类的定义),下面是SQL92和SQL99标准为图4-11中的每个几何类定义的属性和方法。一、几何体Geometry 几何体Geometry是几何对象类等级树的树根,是所有基本空间几何体的超类,是一个不能实例化的抽象类。几何体Geometry类等级中所有的基本几何对象都采用相同的空间参照系统。(一)几何体Geometry 的属性:Dimension对象的空间延展度。点-0维,线-1维,面-2维。CoordinateDimension对象的坐标维,即使用坐标系的维数。,几何对象模型(几何
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 空间 数据库 第四
链接地址:https://www.31ppt.com/p-6596449.html