oracle pl/sql存储过程如何执行,我选项目后右键test测试什么反应都没有
insertintocare.his_info_user_vip_levelselecta.*,to_char(add_months(sysdate,-1),'yyyym...
insert into care.his_info_user_vip_level
select a.*,to_char(add_months(sysdate,-1),'yyyymm'),sysdate from care.info_user_vip_level a
where acct_month<to_char(add_months(sysdate,-1),'YYYYMM')
and vip_level ='P14';
commit;
update care.info_user_vip_level set last_level=vip_level,vip_level = 'PT',assess_date = sysdate,flag='N',acct_month=to_char(add_months(sysdate,-1),'YYYYMM'),card_number=null
where acct_month<to_char(add_months(sysdate,-1),'YYYYMM')
and vip_level ='P14'
******************************************
PROCEDURE EveryMonthAssess(out_err out number)里面都是一些插入和修改语句,F9 和test后既不报错,也没见test页面有什么变化 展开
select a.*,to_char(add_months(sysdate,-1),'yyyymm'),sysdate from care.info_user_vip_level a
where acct_month<to_char(add_months(sysdate,-1),'YYYYMM')
and vip_level ='P14';
commit;
update care.info_user_vip_level set last_level=vip_level,vip_level = 'PT',assess_date = sysdate,flag='N',acct_month=to_char(add_months(sysdate,-1),'YYYYMM'),card_number=null
where acct_month<to_char(add_months(sysdate,-1),'YYYYMM')
and vip_level ='P14'
******************************************
PROCEDURE EveryMonthAssess(out_err out number)里面都是一些插入和修改语句,F9 和test后既不报错,也没见test页面有什么变化 展开
展开全部
如果:PROCEDURE EveryMonthAssess(out_err out number)是你的开头,那么你直接是看不到变化的,因为你的输出只有的error的时候才会输出吧。
你看看你的表中,care用户下的his_info_user_vip_level,是不是已经修改了?另外如果编译没有错误,那么你可以考虑调试一下,就是分步执行,pl/sql developer中可以分步调试的,然后一步一步的看。
不过我估计是你的表里面的内容改了,但是你直接是看不到内容的。
如果真的没改,那么就一步一步调试吧,这个没什么好办法。
你看看你的表中,care用户下的his_info_user_vip_level,是不是已经修改了?另外如果编译没有错误,那么你可以考虑调试一下,就是分步执行,pl/sql developer中可以分步调试的,然后一步一步的看。
不过我估计是你的表里面的内容改了,但是你直接是看不到内容的。
如果真的没改,那么就一步一步调试吧,这个没什么好办法。
展开全部
不管你创建的触发器是insert
,update
,delete类型!
其执行顺序都是按照的你sql语句!
你一条sql语句不会执行三种类型,所以没啥顺序!
如,a表创建了触发器有这三种类型
!
在你操作a表的删除语句时,a表就只会去寻找delete要执行的语句!
,update
,delete类型!
其执行顺序都是按照的你sql语句!
你一条sql语句不会执行三种类型,所以没啥顺序!
如,a表创建了触发器有这三种类型
!
在你操作a表的删除语句时,a表就只会去寻找delete要执行的语句!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
额,你这个如果有参数的话 你要填写参数的。或者你直接文件-》 cmd line窗口后。call pro_name 执行。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
点test后,点了执行么?
不科学呀
不科学呀
更多追问追答
追问
F9 后 傍边有个绿色三角,那个应该就是执行了吧,那个我点了
追答
DECLARE
--out_msg是输出参数
--out_msg VARCHAR2(50);
out_err number;
BEGIN
-- Call the procedure
EveryMonthAssess(out_err);
END;
这样执行看看
不知道你用的什么工具,工具不同吧,不过执行代码总是相同的
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询