- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试创建一个要从网络 map 调用的函数(在数据库级别)。该功能使用户单击某个点时,也可以选择/突出显示关联的区域(多边形)。点和区域通过称为code
的列中的值在属性级别上关联(eks。不在空间上)。
我创建了以下代码,但它返回错误:
ORA-00932: inconsistent datatypes: expected CHAR MDSYS.SDO_GEOMETRY (?)
create or replace function region_select
(
p_geom in sdo_geometry
)
RETURN SDO_GEOMETRY
DETERMINISTIC
IS
v_pointId number;
v_code number;
geom_out sdo_geometry;
BEGIN
select point_id into v_pointId from points where geom = p_geom;
select code into v_code from points where point_id = v_pointId;
if (v_pointId is not null)
then
select geom into geom_out from regions where code = v_code;
RETURN geom_out;
end if;
-- error handling
exception
when others then
raise_application_error(-20001,'An error was encountered - '||
sqlcode ||' -error- '|| sqlerrm);
rollback;
end;
最佳答案
首先,where geom = p_geom
显示使用了空间选择(不是用于REGIONS,而是用于POINTS)-并且您无法使用where geom = p_geom
检查几何相等性。您应该使用select point_id into v_pointId from points t where SDO_EQUALS(t.geom,p_geom) = 'TRUE'
-前提是存在POINTS.geom的空间索引。如果不能有空间索引并且表POINTS很小,则可以使用where sdo_geom.relate(t.geom,'determine',p_geom)='EQUAL'
-但速度会很慢...
其次,我同意@Alex Poole的观点,即这种错误处理不仅没有意义,而且有害。它的编写方式将导致错误(无论如何您都会得到该错误,但不会出现异常),但是您将丢失例如发生此错误的位置。首先,您应该摆脱它,运行代码,看看您是否对错误有更好的描述(CHAR MDSYS.SDO_GEOMETRY
?在哪一行显示“CHAR”?)。如果您所得到的不再透露更多信息,我们将为您提供帮助...
附带说明一下,我不确定此函数是否确实是确定的-您必须确保它是确定的(为什么要这样声明它?这里的目的是什么?)。最后,最好将几何变量声明为“MDSYS.SDO_GEOMETRY
”,而不仅仅是“SDO_GEOMETRY”-旧错误可能会再次咬住您...
HTH,让我知道您是否还有其他需要。
关于oracle - Oracle函数错误: ORA-00932: inconsistent datatypes: expected CHAR got MDSYS.SDO.GEOMETRY,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56354631/
获取错误 ORA-00932: inconsistent datatypes: expected CHAR got NUMBER 00932. 00000 - "inconsistent dataty
我的main.sass中有这个: #thing { -moz-box-sizing: border-box; -webkit-box-sizing: border
在 Python 中,为什么 [:] 切片操作的行为不一致? 它对于列表和字符串的行为有所不同。 对于列表,它给出一个副本列表对象,对于字符串,它给出相同的字符串对象。 我觉得这令人困惑,违反直觉。有
在检查和测试正则表达式的各个方面时,我偶然发现了一种奇怪且“不一致”的行为。我试图在正则表达式中使用一些代码,但同样的行为也适用于使用 void 代码块。 尤其是最让我感动的是,当我互换 :g 和 :
已连接两个支持蓝牙的设备。一个通过outputStream向另一个发送周期性时间戳(writeTime),另一个通过inputStream检索writeTimes并附加自己的时间戳(readTime)
我有以下距离矩阵: delta = [[ 0. 0.71370845 0.80903791 0.82955157 0.56964983 0. 0.
我正在使用 recyclerView 并将数据加载为 arrayList。如果 arrayList 少于 7 个项目,则不会发生崩溃。 否则,我会遇到这个 fatal error : java.lan
为什么结果是: double a = 0.0/0.0; double b = 0/0.0; = NaN 但是结果例如: double e = 0.1/0.0; double e = 12.0/0.0;
这是我的 Java 1.6 类: public class Foo { private ArrayList names; public void scan() { if (names
我正在制作一个使用 encog 预测足球比赛结果的程序。我创建了一个神经网络,使用弹性传播训练方法使用 90 场比赛的数据对其进行训练。我将比赛结果标记为 1 表示主场获胜,0 表示平局,-1 表示客
我正在向我的 App 类中正在进行的 WPF 应用程序添加一些可绑定(bind)的 CLR 属性,但由于这个不一致的可访问性错误,我无法编译。 Inconsistent Accessibility:
我正在尝试使用带有以下参数的 solve.QP 函数(来自 quadprog 包)运行优化 R = matrix( c( 2.231113e-05,-4.816095e-05,-5.115287e-0
我的 solr 架构中有以下两个字段: 当我在启用 facet 的情况下发出请求(faceting on brand_id) http://example.com/solr/select?wt=j
我在 UIView 上有一个 UIButton。我想以编程方式确定显示 View 时在按钮内显示哪个图像。我已经重写了 UIView 中的 drawRect 方法并使用 setImage 来显示所需的
在常规中: println 'test' as Boolean //true println 'test'.toBoolean() //false println new Boolean('test'
例如,在 message.properties 中空白字段的默认 i18n 消息是: default.blank.message=Property [{0}] of class [{1}] canno
我正在尝试使用 array_multisort() 在其子数组的基础上对数组进行排序功能...... 在尝试的同时; print_r($mar); echo ''; $arr2 = array_mul
我正在使用 MALLET 来训练 ParallelTopicModel。训练后,我得到一个 TopicInferencer,取一个句子,通过推理器运行 15 次,然后检查结果。我发现对于某些主题,每次
1) 为什么在 JavaScript 中存在这种不一致 - 我期望第四行也返回 11: (function(n, m) { n = n + m; return n })(3, 8)
上下文: 我有一个小部件,它基本上由一个包装了一堆 TextView 的 RelativeLayout 组成。这是我希望小部件的外观,然后是 XML 布局代码: 问题:我
我是一名优秀的程序员,十分优秀!