Ejemplo: Crear una vista espacial en DB2 con SQL y registrarla

Complejidad: Principiante Requisitos de datos: Usar datos propios

Puede utilizar SQL para crear una vista espacial en una geodatabase de ArcSDE al incluir la columna espacial en la definición de la vista. Si utiliza SQL para crear la vista espacial, debe registrarla con ArcSDE para consultarla con ArcGIS y visualizarla como una clase de entidad.

En este ejemplo, se crea una vista espacial entre la tabla de empleados y la clase de entidad regiones.

Crear una vista con una columna espacial

Defina la vista para incluir la columna espacial y el Id. de objeto de la clase de entidad junto con otras columnas de atributos que desee en la vista.

El propietario de la tabla de empleados y la clase de entidad regiones es el usuario gdb; por lo tanto, este ya tiene los privilegios necesarios para crear la vista.

db2 => connect to testdb user gdb using gdb.dbg     Database Connection Information  Database server      = DB2 9.5.5  SQL authorization ID = GDB  Local database alias = TESTDB  CREATE VIEW emp_region_vw  AS SELECT (e.emp_name,e.emp_id,r.rname,r.reg_id,r.region) FROM employees e, region r WHERE e.emp_id = r.emp_id;

El reg_id es la columna de enteros, no nulos de la clase de entidad regiones que se utilizará como el Id. de fila cuando registre la vista con ArcSDE. Región es la columna espacial de la clase de entidad regiones.

Otorgar privilegios en la vista espacial

Una vez creada la vista, otorgue privilegios selectos al usuario dispatch1. Incluya WITH GRANT OPTION para permitir que el usuario dispatch1 otorgue privilegios en la vista a otros usuarios.

GRANT SELECT ON emp_region_vw TO USER dispatch1 WITH GRANT OPTION;

Registrar la vista con ArcSDE como una capa

Para consultar la vista espacial con ArcGIS, debe registrar la vista como una capa con ArcSDE. Al hacer esto se agregan registros a las tablas del sistema ArcSDE LAYERS y GEOMETRY_COLUMNS.

La capa debe ser registrada por el propietario de la vista; por lo tanto, el nombre y la contraseña del usuario gdb se deben suministrar con las opciones –u y –p.

sdelayer -o register -l emp_region_vw,region -e a  -t ST_GEOMETRY -C reg_id,USER -E 2.20,2.20,3.01,3.01  -R 1 -s mydb2server -i sde:db2 -D testdb -u gdb -p gdb.bdg

Los valores que proporcione para las opciones, excepto –o, variarán según los datos.

Para obtener más información acerca del comando sdelayer, consulte la Referencia sobre el comando de administración.


3/6/2012