如何在外部数据库中存储空间化表时使用Mapinfo_mapcatalog

开始创建地图目录表之前
您将使用EasyLoader在要使用的数据库中创建地图目录表。EasyLoader与MapInfo Pro一起安装。
(工具“DBMS_Catalog”不再随MapInfo Professional 64位一起提供,因为它的功能可以在EasyLoader工具中找到。)

注:EasyLoader也可以从Precisly股份有限公司网站免费下载。如果您下载了EasyLoader的副本,则必须确保您拥有与MapInfo Pro相同版本的EasyLoaders才能将它们一起使用。

http://www.pbinsight.com/support/product-downloads/for/easyloader

在开始之前,您必须提醒数据库管理员注意以下事项:

· 您需要管理员权限才能读取和写入数据库服务器。即使您只读取服务器上的表,您仍然需要写访问权限才能创建EasyLoader,然后让MapInfo Pro写入Map Catalog表。

· EasyLoader在创建Map Catalog表的同时,在服务器级别创建一个MAPINFO模式。.

· EasyLoader为数据库创建一个MAPINFO用户。

您的数据库管理员可能希望手动设置数据库访问权限,从而避免使用EasyLoader。如果数据库管理员希望手动创建地图目录表


在DBMS中创建地图目录

MapInfo Pro将有关空间表和视图的信息存储在数据库中。它将这些信息存储在一个名为MAPINFO的文件中。MAPINFO_MAPCATALOG(映射目录)作为您正在访问的DBMS上的一个特殊表。

MAPINFO_MAPCATALOG是数据库的注册表表,用于存储数据库中空间表和视图的元数据。MAPINFO_MAPCATALOG以表名和所有者名称为键,标识空间类型、空间列(如果有多个)、投影、数据边界和格式副本信息。包括MAPINFO Pro在内的许多MAPINFO产品都使用MAPINFO_MAPCATALOG来访问数据库中的地图数据。

每个数据库必须有一个目录,这是在MapInfo Pro中映射该数据库上的任何表之前所必需的.

手动创建MapInfo_MapCatalog

要手动创建MAPINFO_MAPCATALOG,请执行以下操作:

1.如果RDBMS需要所有者和用户,那么在可映射表所在的特定数据库中使用PASSWORD MAPINFO创建用户MAPINFO。

2. 在数据库中创建表MAPINFO_MAPCATALOG。

Create Table语句必须等效于以下SQL Create Table语句:


如何在外部数据库中存储空间化表时使用Mapinfo_mapcatalog_第1张图片

重要的是,表的结构与此语句完全相同。唯一可以进行的替换是支持varchar或文本数据类型的数据库;这些数据类型可以替代Char数据类型。

3. 在TABLENAME和OWNERNAME上创建一个唯一的索引,这样每个所有者只能映射一个表。

4. 向MAPINFO_MAPCATALOG上的所有用户授予选择权限。这允许用户使表可映射。数据库管理员必须自行决定授予“更新”、“插入”和“删除”权限。

空间索引类型

空间索引类型应用于DBMS表中具有空间信息的列。空间索引为MapInfoPro提供了一种快速访问表中空间数据的方法。可供选择的索引类型有。


如何在外部数据库中存储空间化表时使用Mapinfo_mapcatalog_第2张图片

当没有索引时,可以使用“XY坐标”选项

手动使远程表可映射

对于要在MapInfo Pro中访问的远程数据库中的每个空间表,必须在MapInfo_MAPCATALOG表中添加一行。当在“表”选项卡上的“维护”组中,单击“维护”,然后单击“使DBMS表可映射”时,这将在MapInfo Pro中执行。

如果不使用MapInfo Pro管理地图目录,则必须为数据库中要进行地理编码的每个空间表手动向MapInfo_MAPCATALOG表中添加行。每个条目都必须包含有关该表的以下信息。


如何在外部数据库中存储空间化表时使用Mapinfo_mapcatalog_第3张图片

你可能感兴趣的:(数据库,oracle)