db2函数存储过程
❶ DB2中建立存储过程的详细参数和语法
DECLARE CHOICE2 CURSOR WITH RETURN TO CALLER FOR --声明游标 CHOICE2
SELECT COMPANYID,DEPTID,SEQID,SUBMITTIME,SUBMITDATE,
B.GRADEDESC HYEAR,PRODUCTID,PRODUCTCODE,PRODUCTDESC,
A.GRADEID,PRICE,SFZDPY,LQUANT,MQUANT,MCQUANT,LCQUANT,
UQUANT,OTHQUANT1,OTHQUANT2,OTHQUANT3,OTHQUANT4,EMP1,EMP2,STATUS,A.REMARK,
DECIMAL(ABS(MCQUANT-MQUANT)/NULLIF(MQUANT,0)*100,10,2)TAG
FROM T_SUPPLY_PPB_HY A
LEFT JOIN T_SUPPLY_GRADATION B ON A.GRADEID=B.GRADEID
WHERE HYEAR=TO_CHAR(P_NF)||P_BN
ORDER BY B.GRADEID,PRODUCTCODE,A.PRICE;
--1.DECIMAL(P,S)十进制数,小数点位置由数字的精度(P)和小数位(S)确定。
-- 精度是数字的总位数,必须小于32。小数位是小数部分数字的位数且总是小于或等于精度值。
-- 如果未指定精度和小数位,则十进制值的缺省精度为5,缺省小数位为0。
--2.语法:NULLIF ( expression , expression )
-- expression:(常量、列名、函数、子查询或算术运算符、按位运算符以及字符串运算符的任意组)
-- 如果两个表达式不相等,NULLIF 返回第一个 expression 的值。如果相等,NULLIF 返回第一个 expression 类型的空值。如果两个表达式相等且结果表达式为 NULL,NULLIF 等价于 CASE 的搜索函数。
❷ 如何在DB2的存储过程中用BLOB
要保存图片的字段列的类型设置成image
然后插入的时候,取它的绝对路径
insert into 表名 values(@"C:/123.JPG")
可以用BLOB(string)函数将字符串转化为blob再插入,如下:
create table test(c1 blob(200)); insert into test values(blob('Hello, world'));
其他的方法可能需要用别的语言来写了,这种是在数据库下操作
❸ db2如何调用带out参数的存储过程
declare 出参变量1 ...;
出参变量2...;
.....;
出参变量N...;
begin
过程(入参1,入参2,...,入参N,出参1,出参2,...,出参N);
end;
/
❹ DB2存储过程转换成Oracle要注意什么。。。语句差异有哪些。。。尽量详细。。。有例子最好。
其实我感觉基本没有太大的差别,包括自定义函数的创建和使用方式,但是要注意函数的使用,可能db2里的相关函数在oracle中是另外的名字(大多是一样的,但是有些函数可能oracle不支持,或者是其他),还比如变量的赋值 oracel中是 a:=1,个人觉得oracle的plsql的形式和方便性要好一些。
❺ 如何在DB2中执行存储过程
1、db2
create
database
数据库名
<--
创建数据库
2、db2
connect
to
数据库名
user
用户名
using
用户密码
<--
连接数据库
3、db2
-tvf
otpdb_v3_db2.sql
<--
为新建数据库建立表结构
4、db2
-td@
-f
存储过程文件绝对路径
<--
导入存储过程,无错误会提示成功
4、调用存储过程:
Windows
下:db2
call
存储过程名(参数1,参数2)
AIX
下:db2
<--
要先进入DB2,方可调用存储过程或执行SQL语句
db2=>call
存储过程名(参数1,参数2)
5、验证插入数据是否成功
Windows
下:db2
select
count(*)
from
FTOTP_USERINFO
AIX
下:db2
<--
要先进入DB2,方可调用存储过程或执行SQL语句
db2=>select
count(*)
from
FTOTP_USERINFO
Windows
下:db2
select
count(*)
from
FTOTP_TOKENINFO
AIX
下:db2
<--
要先进入DB2,方可调用存储过程或执行SQL语句
db2=>select
count(*)
from
FTOTP_TOKENINFO
6、db2
SELECT
TOKEN,
PUBKEY
FROM
FTOTP_TOKENINFO
FETCH
FIRST
10000
ROWS
ONLY
>
要保存文件的绝对全路径
<--
从
DB2
中导出前一万条记录
windows
-
e.g.
db2
SELECT
TOKEN,
PUBKEY
FROM
FTOTP_TOKENINFO
FETCH
FIRST
10000
ROWS
ONLY
>
c:\abc.txt
AIX
-
e.g.
db2
SELECT
TOKEN,
PUBKEY
FROM
FTOTP_TOKENINFO
FETCH
FIRST
10000
ROWS
ONLY
>
c:\abc.txt
<--
注意:不能先进入DB2,执行查询与导出命令组合
7、db2
drop
procere
存储过程名
<--
删除存储过程
8、db2
drop
database
数据库名
<--
删除指定名称的数据库
注,如果删除时提示有应用程序连接到这个数据库上,可以用如下命令断开所有应用程序的连接:
db2
force
application
all
<--
断开所有应用程序的连接
❻ mybatis调用db2存储过程,报-440错误
你的PROC_REPORT_GZSLTJBYY是函数还是存储过程啊?要是函数的话,要加1个参数,jdbc调用函数的时候,会把返回值作为第一个参数。
❼ db2存储过程里面可以用like么
db2存储过程里面可以用like
DB2中的like的使用是有限制的,它不允许跟在它后面的是一个变量或者是字段,目前比较多的是:like '%测试%'这样.
因此,在函数或者是存储过程中,就不能通过窗体一个参数给like来组成动态的条件。
如果真要在函数或者是存储过程中,去搜索某个字段是否拥有某个字符串在里面,可以使用locate。
下面是locate的用法:
locate(arg1,arg2,<pos>):在arg2中查找arg1第一次出现的位置,指定pos,则从arg2的pos处开始找arg1第一次出现的位置。
下面是用该方法时的一个例子:
CREATE FUNCTION GDZJ.GETNOPASS
(ITEMNAME VARCHAR(100),
REPORTTYPE INTEGER,
RESULTID INTEGER
)
RETURNS INTEGER
SPECIFIC GDZJ.SQL091102183311900
LANGUAGE SQL
NOT DETERMINISTIC
READS SQL DATA
STATIC DISPATCH
CALLED ON NULL INPUT
EXTERNAL ACTION
INHERIT SPECIAL REGISTERS
begin atomic
--返回值0:没有该检验项目。1:有检验项目,但全部合格。2:有检验项,但有一个不合格。(只要有一个不合格就判其不合格)
DECLARE IResult INTEGER;
DECLARE ICount INTEGER;
set IResult=0;
--REPORTTYPE:1:外单位、0:非外单位
if REPORTTYPE=1 then
set ICount=(
select count(1) from DETECT_END_INFO where
CHECK_OUT_UNIT_INFO_ID=RESULTID and locate(ITEMNAME,PROJECT_NAME)>0
end;
❽ 在db2的命令行如何创建存储过程和函数
1.首先连接数据库 2.发出一下命令: DB2 -td@ -vf createSQLproc.DB2 createSQLproc.DB2文件中是创建存储过程的SQL语句; -td 选项让命令行处理程序使用@作为语句终止字符; -v 选项让命令处理程序将命令文本回显到标准输出; -f 让命令行处理程序从指定文件读取命令输入。
❾ 调用db2存储过程的时候报错报错
declare 出参变量1 ...; 出参变量2...; .....; 出参变量N...;begin 过程(入参1,入参2,...,入参N,出参1,出参2,...,出参N);end;/