问题与Oracle(空间几何形状)的查询(Problem with Oracle (Spatial

2019-09-29 06:59发布

我试图形成返回给定矩形内的实体的列表,使用SDO_WITHIN_DISTANCE查询。 我所做的查询好像它应该工作,但甲骨文是给我一些奇怪的错误。 这里的查询:

SELECT * 
FROM TBLENTITYLOCATION TL
      INNER JOIN TBLENTITY TE 
      ON TE.ENTITYID=TL.ENTITYID  
WHERE SDO_WITHIN_DISTANCE (TL.GEOLOCATION
                           , SDO_GEOMETRY (2003
                                         , NULL
                                         , NULL
                                         , SDO_ELEM_INFO_ARRAY(1, 1003, 3)
                                         , SDO_ORDINATE_ARRAY(41, -73, 36, -82)
                              ), 'DISTANCE=10 UNIT=M'
                          ) = 'TRUE' 
AND  TL.LOCATIONDATETIME= (select MAX(LOCATIONDATETIME) 
                           FROM TBLENTITYLOCATION 
                           WHERE  ENTITYID = TE.ENTITYID)

错误如下:

ORA-29902: error in executing ODCIIndexStart() routine
ORA-13208: internal error while evaluating [window SRID does not match layer SRID] operator
ORA-06512: at MDSYS.SDO_INDEX_METHOD_10I", line 286

OERR说:

29902. 00000 -  "error in executing ODCIIndexStart() routine"
*Cause:    The execution of ODCIIndexStart routine caused an error.
*Action:   Examine the error messages produced by the indextype code and take appropriate action.

感谢您的任何帮助或想法。

Answer 1:

该ORA-13208错误是这里的主要之一。 该TL.GEOLOCATION在SRID(所述SDO_GEOMETRY的第二个参数)需要一个匹配值

查看是否响应这里帮助你的。



Answer 2:

加里·迈尔斯提供正确的答案,让我增强了。 如果你不知道哪个SRID所使用的表格做,做一个查询:

select SRID from USER_SDO_GEOM_METADATA where TABLE_NAME='TBLENTITYLOCATION' and COLUMN_NAME='TBLENTITYLOCATION'

此外,来查询它们的矩形内的对象,你不需要SDO_WITHIN_DISTANCE运营商。 相反,使用SDO_RELATE用面膜= ANYINTERACT。 见http://docs.oracle.com/cd/B12037_01/appdev.101/b10826/sdo_operat.htm#i78531了解更多详情。



文章来源: Problem with Oracle (Spatial Geometry) query