首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > oracle >

问两个关于proc的有关问题

2012-01-16 
问两个关于proc的问题1.我想问一下在EXECSQLupdate……之后,怎么取得这个语句在执行后被数据库被更新的记录

问两个关于proc的问题
1.我想问一下在EXEC   SQL   update   ……之后,怎么取得这个语句在执行后被数据库被更新的记录数?
2.select   aa   into   :c   from   table1   where   b=1,   如果这里aa是一个变量,代表具体的字段名,怎么写EXEC   SQL语句?

[解决办法]
第一个你用一个count就好了吧,你update的时候肯定有个where的,你在update 之前count一下where就可以了
[解决办法]
1.我想问一下在EXEC SQL update ……之后,怎么取得这个语句在执行后被数据库被更新的记录数?


SQL%ROWCOUNT 记录的影响行数

---
EXECUTE IMMEDIATE v_sql;

IF SQL%ROWCOUNT = 0 --当记录数为0时。。。。
THEN
...
END IF;
[解决办法]
2.select aa into :c from table1 where b=1, 如果这里aa是一个变量,代表具体的字段名,怎么写EXEC SQL语句?


declare 变量C 变量类型;
begin
select aa into 变量C from table1 where b=1;
end;

--这样就可以了
[解决办法]
如冰所说
[解决办法]
第二个问题他是指烈名是动态的吧?
那样用动态sql
[解决办法]
第一个问题,查看
sqlca.sqlerrd[2]
第二个问题,使用动态SQL语句,比如prepare语句
查看例子代码
sprintf(dynstmt.arr,
"select %s into :c from table1 where b=1 ",aa);
dynstmt.len = (unsigned short)strlen((char *)dynstmt.arr);
EXEC SQL PREPARE S FROM :dynstmt;
EXEC SQL DECLARE C CURSOR FOR S;
EXEC SQL OPEN C ;

[解决办法]
1、SQL%ROWCOUNT
2、先声明变量declare

热点排行