IBM DB2数据库与注意事项_DB2编程的描述

数据库
以下的文章主要向大家描述的是应用经验之关于IBM DB2数据库在实际操作中的注意事项_DB2编程的描述,以下就是正文的主要内容讲述。

此文章主要向大家讲述的是应用经验之关于IBM DB2数据库在实际操作中的注意事项_DB2编程的描述,以及对假如你的数据库服务端不在本机这一情况,则需要在“客户机配置辅助程序”中做一个客户端连接的配置的描述。

DB2, IBM DB2, DB2编程

 

1.在安装DB2数据库后,你可以通过命令行方式或图形界面方式来操作,假如你的数据库服务端不在本机,则需要在“客户机配置辅助程序”中做一个客户端连接的配置。

 

2.控制中心中无法增删改数据,只能编写sql语句来实现而quest提供的工具虽然能增加数据,但居然无法用复制、粘贴和Tab键,必须逐个输入,然后用鼠标点击切换现存数据看来可以在单元格中编辑修改,但实际却无法commit,呵呵,还是老老实实写update语句,至于删除数据,更是非写delete语句不可。

不过可以用pb以单元格方式编辑数据,相应的一个缺点是编辑数据的按钮和删除表的按钮太近,万一点错了删除表的按钮,pb可是不作提示就把表给删了的,faint

3.DB2的视图里不能直接用order by语句,必须这样写:

  1. select × from(select a,b,c from table1 order by a)as tab  

注释:这种写法的前提是你已经打过补丁了

 

4.存储过程的问题: DB2提供ltrim函数和rtrim函数,但偏偏不提供trim函数,如果你希望去除字符两端的空格,对不起,必须用ltrim(rtrim()) 的方式调用insert 语句里面居然不能用表达式赋值,必须把值先赋给一个变量调用其他存储过程时竟然不能用常量做参数,必须把这个常量的值赋给一个变量,

再以这个变量为参数

 

select * from table fetch first n rows only 语句居然在存储过程里不可用

 

5.存储过程里可以使用动态sql,但函数里却不可以使用

6. 遇到commit或rollback时自动关闭游标,所以需要慎重使用单独提交。

proc builder老是在调试中内存不足,屏幕花掉。而如果断点调试时暂停不进行下去的时间稍微长一点就会提示超时,受不了。

 

7.开发问题: 在使用 日期变量+1 MONTHS OR 日期变量-1 MONTHS 的方式取日期时,比如IBM DB2数据库日期变量值为 2004-02-29时,存储过程里将日期变量+1 MONTHS 赋值给另一

日期变量时会出错。

 

相应SQLSTATE为01506(db2 ? 01506): 对 DATE 或TIMESTAMP值进行了调整,以校正算术运算得出的无效日期。

如果要获取的只是下一月份,可采用的替代方法是获取当前日期所在月份的***天作为基准后+1 MONTHS OR -1 MONTHS

 

8.对变量的赋值不能用select ..into ..方式而要用set v=(select ..)的方式,具体的示例如下:

  1. drop function SXFM.ISORDERSUBMITDATE;  
  2. CREATE FUNCTION SXFM.ISORDERSUBMITDATE(IN_ROW_ID DECIMAL(16,0))   
  3. RETURNS DATE   
  4. LANGUAGE SQL   
  5. BEGIN ATOMIC   
  6. DECLARE V_SUBMIT_DATE DATE;   
  7. DECLARE V_SELL_ID DECIMAL(16, 0);   
  8. DECLARE V_BUY_ID DECIMAL(16, 0);   
  9. set V_SELL_ID = (SELECT COALESCE(RECEIVE_ID,-1) FROM IS_ORDER WHERE ROW_ID=IN_ROW_ID);   
  10. set V_BUY_ID = (SELECT COALESCE(PAY_ID,-1) FROM IS_ORDER WHERE ROW_ID=IN_ROW_ID);   
  11. set V_SUBMIT_DATE = (SELECT DATE(MAX(A.SUBMIT_DATE)) FROM AM_AUDIT_QUEUE A,SM_USER B,SM_USER C  
  12. WHERE A.TABLE_CODE=’IS_ORDER’ AND A.TABLE_ROW_ID=IN_ROW_ID   
  13. AND A.AUDIT_EMP_ID=C.ROW_IDAND C.BRANCH_ID=V_BUY_ID  

审核方为付款方

  1. AND A.SUBMIT_EMP_ID=B.ROW_ID AND B.BRANCH_ID=V_SELL_ID);  

提交方为收款方

  1. RETURN V_SUBMIT_DATE;   
  2. END;   
  3. #SYNC 10; 

以上的相关内容就是对关于IBM DB2数据库的注意事项_DB2编程的介绍,望你能有所收获。

【编辑推荐】

  1. 备份DB2数据库在AIX上谁说很拽?
  2. DB2重定向恢复失败“水到渠成”
  3. DB2 Online备份的操作方案“盛宴”
  4. DB2恢复删除表的实际操作技巧演示
  5. DB2数据库备份,恢复命令的操作经验总结

 

责任编辑:佚名 来源: 泡泡网
相关推荐

2011-03-14 17:51:04

IBMDB2数据库

2010-08-06 15:27:14

DB2 batch u

2010-09-07 13:22:36

IBM DB2

2010-08-04 10:44:32

2010-08-31 10:53:18

DB2导入数据库

2010-07-29 13:56:32

2010-11-01 13:24:15

DB2数据导入

2010-08-09 09:05:41

DB2快照函数

2009-07-06 17:34:26

远程复制DB2

2010-07-27 10:11:18

DB2数据库临时表

2010-07-30 13:28:10

2009-03-25 17:43:09

备份DB2IBM

2010-07-27 14:33:24

DB2数据库

2010-08-04 11:23:59

2010-08-11 12:43:45

DB2数据库调优

2010-08-04 13:37:43

2010-08-04 15:59:29

2010-08-13 15:42:22

DB2数据库分区

2011-03-11 16:02:03

DB2数据库安装

2010-09-06 10:30:14

DB2数据库临时表
点赞
收藏

51CTO技术栈公众号