Oracle 将一个查询结果值动态赋值给一个变量
2017-11-07 21:39
603 查看
在写存储过程或函数时,经常需要用到中间变量,需要将一些值做临时存储。
可以通过动态变量方式来赋值。如下:
以上语句在条件A=1满足时,能够成功赋值给变量MID_ID,但如果没有查询到值时,该语句在执行时会报错(因为未查询到值)
可以在查询值外加入MAX() 或 MIN() 如下处理:
如果条件A=1不满足时,会返回一个空值,不会出现报错情况。这种应用在某种场景时很有用:当需要根据获得的动态变量值做分支判断时。
参考以下代码:
如果以上代码变量赋值不加入MAX(ID)时,当A=1的条件不满足时,动态赋值语句会报错,执行将中断,将不会走到 IF -ELSE 分支判断。
以上是一个Oracle存储过程使用中的一个技巧,留意下。
可以通过动态变量方式来赋值。如下:
FUNCTION YOUR_FUN (VAL1 IN NVARCHAR2) RETURN NCLOB IS PRAGMA AUTONOMOUS_TRANSACTION; MID_ID NUMBER (19); --中间变量 BEGIN SELECT ID INTO MID_ID FROM TABLE1 WHERE A = 1; END;
以上语句在条件A=1满足时,能够成功赋值给变量MID_ID,但如果没有查询到值时,该语句在执行时会报错(因为未查询到值)
可以在查询值外加入MAX() 或 MIN() 如下处理:
FUNCTION YOUR_FUN (VAL1 IN NVARCHAR2) RETURN NCLOB IS PRAGMA AUTONOMOUS_TRANSACTION; MID_ID NUMBER (19); --中间变量 BEGIN SELECT MAX(ID) INTO MID_ID FROM TABLE1 WHERE A = 1; END;
如果条件A=1不满足时,会返回一个空值,不会出现报错情况。这种应用在某种场景时很有用:当需要根据获得的动态变量值做分支判断时。
参考以下代码:
FUNCTION YOUR_FUN (VAL1 IN NVARCHAR2) RETURN NCLOB IS PRAGMA AUTONOMOUS_TRANSACTION; MID_ID NUMBER (19); --中间变量 BEGIN SELECT MAX(ID) INTO MID_ID FROM TABLE1 WHERE A = 1; IF MID_ID > 0 THEN --一些逻辑处理 COMMIT; ELSE --另一些逻辑 COMMIT; END IF; END;
如果以上代码变量赋值不加入MAX(ID)时,当A=1的条件不满足时,动态赋值语句会报错,执行将中断,将不会走到 IF -ELSE 分支判断。
以上是一个Oracle存储过程使用中的一个技巧,留意下。
相关文章推荐
- JAVA开发12--将oracle查询结果赋值给JAVA变量
- Oracle 在函数或存储过程中执行sql查询字符串并将结果值赋值给变量
- PL/SQL里拼接SQL的查询结果赋值给一个变量
- grep查询文本:问一个简单shell问题,将grep的输出赋值给一个变量
- oracle 查询两个字段赋值到一个字段的方法
- 将DB2的查询结果赋值给SHELL中的变量方法
- ORACLE 将查询结果中的多个字段值赋给变量
- sp_executesql动态执行sql语句并将结果赋值给一变量
- oracle 将查询结果中的一列多个结果合并为一个字符串 并以逗号格开
- 将查询结果赋值给变量时使用set与select的区别
- php将SQL查询结果赋值给变量
- oracle 动态拼接语句并返回查询结果集
- 在Excel VBA中将SQL查询的结果赋值给变量的方法
- 使用SQL查询语句时,数组动态赋值SQL IN ()作为条件条件一个
- SELECT查询结果集中,如何能够动态添加一个标识列?
- 将一个表的查询结果作为另一查询的字段(动态查询列)
- oracle一列查询结果,用,拼接成一个字符串
- JS/Jquery 中怎么定义存储一个类似map中key-value形式的变量,并且怎样动态赋值key和value?
- Oracle中把一个查询结果插入到一张表中
- 使用SQL查询语句时,数组动态赋值SQL IN ()作为条件条件一个