Ejemplo: Crear una vista espacial en DB2 con SQL y registrarla
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.