Oracle(空间几何)查询的问题

2023-12-22

我正在尝试使用 SDO_WITHIN_DISTANCE 形成一个查询,返回给定矩形内的实体列表。我所做的查询似乎应该有效,但 Oracle 给了我一些奇怪的错误。这是查询:

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

奥尔说:

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.

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


ORA-13208 错误是这里的首要错误。 TL.GEOLOCATION 需要 SRID 中的匹配值(SDO_GEOMETRY 的第二个参数)

看看有没有回应here http://forums.oracle.com/forums/thread.jspa?threadID=218341#602492帮助你。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Oracle(空间几何)查询的问题 的相关文章

随机推荐