我是oracle spatial的新手。
我有一个带有一个SDO_GEOMETRY列的空间表。在此表中插入POINT数据后,我想检索WKT格式的数据。
这是我做的:
插入数据 -
INSERT INTO new_test (name, geom) VALUES (
'Test',
SDO_GEOMETRY(
2001,
4326,
SDO_POINT_TYPE(12,14,NULL),
NULL,
NULL));
获取数据 -
SELECT NAME, SDO_UTIL.TO_WKTGEOMETRY(GEOM) AS point FROM NEW_TEST;
输出 -
NAME | POINT
-------------
Test | (null)
为什么我在这里得到空?它不应该显示坐标点吗?
答案 0 :(得分:1)
评论太长了 - 不知道为什么它不适合你,但我不能复制你的结果:
Oracle安装程序:
CREATE TABLE new_test ( name varchar2(20), geom SDO_GEOMETRY );
INSERT INTO new_test (name, geom)
VALUES (
'Test',
SDO_GEOMETRY( 2001, 4326, SDO_POINT_TYPE(12,14,NULL), NULL, NULL)
);
<强>查询强>:
SELECT NAME, SDO_UTIL.TO_WKTGEOMETRY(GEOM) AS point FROM NEW_TEST;
<强>输出强>:
NAME POINT
---- -----------------
Test POINT (12.0 14.0)
答案 1 :(得分:1)
Express版(Source - Siva Ravada-Oracle )似乎无法使用SDO_UTIL.TO_WKTGEOMETRY
功能:
Oracle Express在数据库和WKT中没有Javavm 转换例程需要这个,因为该功能是作为Java实现的 存储过程。因此,不支持这些WKT例程 快递版。
您仍然可以像这样建立自己的WKT(点数):
SELECT name, 'POINT ('||t.X||' '||t.Y||')' AS point FROM NEW_TEST p, TABLE(SDO_UTIL.GETVERTICES(p.GEOM)) t;