SnowConvert AI - Oracle - Tipos espaciais

Descrição

O Oracle Spatial and Graph foi projetado para tornar o gerenciamento de dados espaciais mais fácil e natural para usuários de aplicativos habilitados para localização, aplicativos de sistemas de informação geográfica (SIG) e aplicativos de geoimagem. (Tipos espaciais de referência de linguagem Oracle SQL)

{ SDO_Geometry | SDO_Topo_Geometry |SDO_GeoRaster }

Copy

SDO_GEOMETRY

Nota

Algumas partes do código de saída foram omitidas por motivos de clareza.

Descrição

A descrição geométrica de um objeto espacial é armazenada em uma única linha, em uma única coluna do tipo de objeto SDO_GEOMETRY em uma tabela definida pelo usuário. Qualquer tabela que tenha uma coluna do tipo SDO_GEOMETRY deve ter outra coluna, ou conjunto de colunas, que defina uma chave primária exclusiva para essa tabela. (Tipo de dados SDO_GEOMETRY da referência de linguagem Oracle SQL)

Definição de objeto SDO_GEOMETRY:

CREATE TYPE SDO_GEOMETRY AS OBJECT
  (sgo_gtype        NUMBER, 
   sdo_srid         NUMBER,
   sdo_point        SDO_POINT_TYPE,
   sdo_elem_info    SDO_ELEM_INFO_ARRAY,
   sdo_ordinates    SDO_ORDINATE_ARRAY);
/

Copy

O objeto SDO_GEOMETRY não é suportado no Snowflake. Uma solução alternativa para esse tipo de dados é usar o Snowflake GEOGRAPHY, mas essa transformação não é compatível com o SnowConvert.

Amostra de padrões da origem

SDO_GEOMETRY em Create Table

Oracle
CREATE TABLE geometry_table(
    geometry_column SDO_GEOMETRY
);
Copy
Snowflake
CREATE OR REPLACE TABLE geometry_table (
        geometry_column GEOMETRY
    )
    COMMENT = '{"origin":"sf_sc","name":"snowconvert","version":{"major":1, "minor":0},{"attributes":{"component":"oracle"}}'
    ;
Copy

Inserção de dados na tabela SDO_GEOMETRY

Oracle
INSERT INTO geometry_table VALUES (
	SDO_GEOMETRY('POINT(-79 37)')
);

INSERT INTO geometry_table VALUES (
    SDO_GEOMETRY('LINESTRING(1 3, 1 5, 2 7)')
);

INSERT INTO geometry_table VALUES (
    MDSYS.SDO_GEOMETRY(
		2001,
		8307,
		MDSYS.SDO_POINT_TYPE (
			-86.13631,
			40.485424,
			NULL),
		NULL,
		NULL
	)
);

INSERT  INTO geometry_table VALUES (
SDO_GEOMETRY(
    2003,
    12,
    SDO_POINT_TYPE(12, 14, -5),
    SDO_ELEM_INFO_ARRAY(1,1003,3),
    SDO_ORDINATE_ARRAY(1,1, 5,7) 
  )
);

INSERT INTO geometry_table VALUES (
NULL);
Copy
Snowflake
INSERT INTO geometry_table
VALUES (
	SDO_GEOMETRY('POINT(-79 37)') !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'SDO_GEOMETRY' NODE ***/!!!
);


INSERT INTO geometry_table
VALUES (
    SDO_GEOMETRY('LINESTRING(1 3, 1 5, 2 7)') !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'SDO_GEOMETRY' NODE ***/!!!
);


INSERT INTO geometry_table
VALUES (
    MDSYS.SDO_GEOMETRY(
		2001,
		8307,
		MDSYS.SDO_POINT_TYPE (
			-86.13631,
			40.485424,
			NULL) !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'MDSYS.SDO_POINT_TYPE' NODE ***/!!!,
		NULL,
		NULL
	) !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'MDSYS.SDO_GEOMETRY' NODE ***/!!!
);

INSERT  INTO geometry_table
VALUES (
SDO_GEOMETRY(
    2003,
    12,
    SDO_POINT_TYPE(12, 14, -5) !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'SDO_POINT_TYPE' NODE ***/!!!,
    SDO_ELEM_INFO_ARRAY(1,1003,3) !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'SDO_ELEM_INFO_ARRAY' NODE ***/!!!,
    SDO_ORDINATE_ARRAY(1,1, 5,7) !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'SDO_ORDINATE_ARRAY' NODE ***/!!!
  ) !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'SDO_GEOMETRY' NODE ***/!!!
);

INSERT INTO geometry_table
VALUES (
NULL);
Copy

Migração usando o tipo de dados GEOGRAPHY

Oracle
CREATE TABLE geometry_table(
    geometry_column SDO_GEOMETRY
);

INSERT INTO geometry_table VALUES (
	SDO_GEOMETRY('POINT(-79 37)')
);

INSERT INTO geometry_table VALUES (
    SDO_GEOMETRY('LINESTRING(1 3, 1 5, 2 7)')
);

/*
--NOT SUPPORTED BY SNOWFLAKE GEOGRAPHY
INSERT INTO geometry_table VALUES (
    MDSYS.SDO_GEOMETRY(
		2001,
		8307,
		MDSYS.SDO_POINT_TYPE (
			-86.13631,
			40.485424,
			NULL),
		NULL,
		NULL
	)
);
INSERT  INTO geometry_table VALUES (
SDO_GEOMETRY(
    2003,
    12,
    SDO_POINT_TYPE(12, 14, -5),
    SDO_ELEM_INFO_ARRAY(1,1003,3),
    SDO_ORDINATE_ARRAY(1,1, 5,7) 
  )
);
*/

SELECT * FROM geometry_table;
Copy
Resultado

GEOMETRY_COLUMN

[2001, null, [-79, 37, null], [NULL], [NULL]]

[2002, null, [null, null, null], [1,2,1], [1,3,1,5,2,7]]

Snowflake
CREATE OR REPLACE TABLE geometry_table (
	    geometry_column GEOMETRY
	)
	COMMENT = '{"origin":"sf_sc","name":"snowconvert","version":{"major":1, "minor":0},{"attributes":{"component":"oracle"}}'
	;

	INSERT INTO geometry_table
	VALUES (
	SDO_GEOMETRY('POINT(-79 37)') !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'SDO_GEOMETRY' NODE ***/!!!
);

	INSERT INTO geometry_table
	VALUES (
    SDO_GEOMETRY('LINESTRING(1 3, 1 5, 2 7)') !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'SDO_GEOMETRY' NODE ***/!!!
);

	/*
--NOT SUPPORTED BY SNOWFLAKE GEOGRAPHY
INSERT INTO geometry_table VALUES (
    MDSYS.SDO_GEOMETRY(
		2001,
		8307,
		MDSYS.SDO_POINT_TYPE (
			-86.13631,
			40.485424,
			NULL),
		NULL,
		NULL
	)
);
INSERT  INTO geometry_table VALUES (
SDO_GEOMETRY(
    2003,
    12,
    SDO_POINT_TYPE(12, 14, -5),
    SDO_ELEM_INFO_ARRAY(1,1003,3),
    SDO_ORDINATE_ARRAY(1,1, 5,7) 
  )
);
*/

SELECT * FROM
	    geometry_table;
Copy
Resultado

GEOMETRY_COLUMN

POINT(-79 37)

LINESTRING(1 3,1 5,2 7)

SDO_GEORASTER

Nota

Algumas partes do código de saída foram omitidas por motivos de clareza.

Descrição

No modelo objeto-relacional GeoRaster, um objeto de imagem ou grade raster é armazenado em uma única linha, em uma única coluna do tipo de objeto SDO_GEORASTER em uma tabela definida pelo usuário. (Tipo de dados SDO_GEORASTER da referência de linguagem Oracle SQL).

Definição de objeto SDO_GEORASTER:

CREATE TYPE SDO_GEORASTER AS OBJECT
  (rasterType         NUMBER,
   spatialExtent      SDO_GEOMETRY,
   rasterDataTable    VARCHAR2(32),
   rasterID           NUMBER,
   metadata           XMLType);
/

Copy

Nota

SDO_GEORASTER está desativado por padrão. Para ativar seu uso, siga as etapas descritas nesta seção da documentação da Oracle.

O objeto SDO_GEORASTER não é suportado no Snowflake.

Amostra de padrões da origem

SDO_GEORASTER em Create Table

Oracle
CREATE TABLE georaster_table(
    georaster_column SDO_GEORASTER
);
Copy
Snowflake
CREATE OR REPLACE TABLE georaster_table (
    !!!RESOLVE EWI!!! /*** SSC-EWI-0028 - TYPE NOT SUPPORTED BY SNOWFLAKE ***/!!!
        georaster_column SDO_GEORASTER
    )
    COMMENT = '{"origin":"sf_sc","name":"snowconvert","version":{"major":1, "minor":0},"attributes":{"component":"oracle"}}'
    ;
Copy
Inserção de dados na tabela SDO_GEORASTER
Oracle
INSERT INTO georaster_table VALUES (null);
INSERT INTO georaster_table VALUES (sdo_geor.init('RDT_11', 1));
Copy
Snowflake
INSERT INTO georaster_table
VALUES (null);

INSERT INTO georaster_table
VALUES (
!!!RESOLVE EWI!!! /*** SSC-EWI-OR0076 - TRANSLATION FOR BUILT-IN PACKAGE 'sdo_geor.init' IS NOT CURRENTLY SUPPORTED. ***/!!!
'' AS init);
Copy

Problemas conhecidos

1. Tipo de dados SDO_GEORASTER não transformado

O tipo de dados SDO_GEORASTER não está sendo transformado pelo SnowConvert.

EWIs relacionados

  1. SSC-EWI-0028: Tipo incompatível.

  2. SSC-EWI-OR0076: Built In Package Not Supported.

SDO_TOPO_GEOMETRY

Nota

Algumas partes do código de saída foram omitidas por motivos de clareza.

Descrição

Esse tipo descreve uma geometria de topologia, que é armazenada em uma única linha, em uma única coluna do tipo de objeto SDO_TOPO_GEOMETRY em uma tabela definida pelo usuário. (Tipo de dados SDO_TOPO_GEOMETRY da referência de linguagem Oracle SQL).

Definição de objeto SDO_TOPO_GEOMETRY:

CREATE TYPE SDO_TOPO_GEOMETRY AS OBJECT
  (tg_type        NUMBER, 
   tg_id          NUMBER,
   tg_layer_id    NUMBER,
   topology_id    NUMBER);
/

Copy

O objeto SDO_TOPO_GEOMETRY não é suportado no Snowflake.

Amostra de padrões da origem

SDO\TOPO_GEOMETRY em Create Table

Oracle
CREATE TABLE topo_geometry_table(
    topo_geometry_column SDO_TOPO_GEOMETRY
);
Copy
Snowflake
CREATE OR REPLACE TABLE topo_geometry_table (
    !!!RESOLVE EWI!!! /*** SSC-EWI-0028 - TYPE NOT SUPPORTED BY SNOWFLAKE ***/!!!
        topo_geometry_column SDO_TOPO_GEOMETRY
    )
    COMMENT = '{"origin":"sf_sc","name":"snowconvert","version":{"major":1, "minor":0},{"attributes":{"component":"oracle"}}'
    ;
Copy

Inserção de dados na tabela SDO_TOPO_GEOMETRY

Oracle
INSERT INTO topo_geometry_table VALUES (SDO_TOPO_GEOMETRY(1,2,3,4));
INSERT INTO topo_geometry_table VALUES (NULL);
Copy
Snowflake
INSERT INTO topo_geometry_table
VALUES (SDO_TOPO_GEOMETRY(1,2,3,4) !!!RESOLVE EWI!!! /*** SSC-EWI-0073 - PENDING FUNCTIONAL EQUIVALENCE REVIEW FOR 'SDO_TOPO_GEOMETRY' NODE ***/!!!);

INSERT INTO topo_geometry_table
VALUES (NULL);
Copy

Problemas conhecidos

1. Tipo de dados SDO_TOPO_GEOMETRY não transformado

O tipo de dados SDO_TOPO_GEOMETRY não está sendo transformado pelo SnowConvert.

EWIs relacionados

  1. SSC-EWI-0028: Tipo incompatível.

  2. SSC-EWI-0073: Pending functional equivalence review.