db2存储过程修改
⑴ 如何在DB2存储过程内部实现export、import或者load等导入导出操作
export to c:/a.del of del select * from a这样可以直接把数据导入到本地目录;
在存储过程中可以这样调用CALL SYSPROC.ADMIN_CMD('export to c:/a.del of del select * from a')只是导出路径要写sever端,这样导出的数据会保存在安装db2数据库的电脑上,而不会保存在客户端上
⑵ 如何给DB2数据库的存储过程中 where 的in 条件传参数
create
or
replace
procere
test(in
in_where
varchar(100))
--创建一个存储过程test,并可以传入字符串作为参数
declare
v_sql
varchar(512);
set
v_sql
=
'
delete
from
table1
where
field1
in
('
concat
in_where
concat
')
'
;
--
这里是把传进来的where语句拼起来
execute
immediate
v_sql;
--这里是把语句进行执行---------类似以上这样的存储过程,使用以下的放在进行执行即可:call
test(
'
''001'',''002''
')
;
--内容中的一个‘
需要使用
’‘
进行转义
⑶ db2创建存储过程在begin和end中间有东西就报错是什么情况
因为在 Unix 平台下的 DB2 存储过程对于实例用户和受防护用户之间的关系有一个约束,即 DB2 实例用户必须同时是受防护用户的主组中的一个用户。
上述问题的发生就是由于在系统上,实例用户未加入至受防护用户的主组中,从而引发了存取权限不够的问题所导致的,而并非真的发生了如日志中所报的磁盘错误。解决这一问题的方法很简单,只要将实例用户加入该主组即可。
但有时用户会发现,即使已将用户加入到指定组,问题仍然存在,这时还应检查一下实例用户所加入的组是否是实例用户所对应的受防护用户的主组,即检查一下加入的组是否正确。
要找到实例用户所应的受防护用户以及受防护用户的主组,可用如下方法:
转入实例用户 Home 路径下的 sqllib/adm 路径。
执行命令:ls -l .fenced,会得到类似如下输出。
r--r--r-- 1 db2fencj db2fgrp2 0 Jul 30 09:57 .fenced。
输出中表明,该文件所属的用户(db2fencj)即为受防护用户,所属的组(db2fgrp2)即为受防护用户的主组
继而,用户便可验证实例用户是否被加入到了正确的组中,如果结果正确,便可以解决上述问题。