手机站
网通分站
电信主站
密 码:
用户名:
当前位置 : 主页>网站运营>建站经验>列表

DB2编程基础要点

来源:互联网 作者:west263.com 时间:2008-04-16
西部数码-全国虚拟主机10强!40余项虚拟主机管理功能,全国领先!双线多线虚拟主机南北访问畅通无阻!免费赠送企业邮局,.CN域名,自助建站480元起,免费试用7天,满意再付款! P4主机租用799元/月.月付免压金!

1 DB2编程

1.1 建存储过程时Create 后一定不要用TAB键

create procedure
的create后只能用空格,而不可用tab健,否则编译会通但是。
切记,切记。

1.2 使用临时表

要注意,临时表只能建在user tempory tables space 上,假如database只有system tempory table space是不能建临时表的。

另外,DB2的临时表和sybase及oracle的临时表不太相同,DB2的临时表是在一个session内有效的。所以,假如程式有多线程,最好不要用临时表,很难控制。

建临时表时最好加上 with replace选项,这样就能够不显示的drop 临时表,建临时表时假如不加该选项而该临时表在该session内已创建且没有drop,这时会发生错误。

1.3 从数据表中取指定前几条记录

select * from tb_market_code fetch first 1 rows only

但下面这种方式不允许:

select market_code into v_market_code
from tb_market_code fetch first 1 rows only;

选第一条记录的字段到一个变量以以下方式代替:

declare v_market_code char(1);
declare cursor1 cursor for select market_code from tb_market_code
fetch first 1 rows only for update;
open cursor1;
fetch cursor1 into v_market_code;
close cursor1;

1.4 游标的使用

注意commit和rollback
使用游标时要特别注意假如没有加with hold 选项,在Commit和Rollback时,该游标将被关闭。Commit 和Rollback有很多东西要注意。特别小心。

游标的两种定义方式:

一种为:

declare continue handler for not found
begin
set v_notfound = 1;
end;

declare cursor1 cursor with hold for

select market_code from tb_market_code for update;
open cursor1;
set v_notfound=0;
fetch cursor1 into v_market_code;
while v_notfound=0 Do
--work
set v_notfound=0;
fetch cursor1 into v_market_code;
end while;
close cursor1;

这种方式使用起来比较复杂,但也比较灵活。特别是能够使用with hold 选项。假如循环内有commit或rollback 而要保持该cursor不被关闭,只能使用这种方式。

另一种为:

pcursor1: for loopcs1 as cousor1 cursor as
select market_code as market_code
from tb_market_code
for update
do
end for;

这种方式的长处是比较简单,不用(也不允许)使用open,fetch,close。

但不能使用with hold 选项。假如在游标循环内要使用commit,rollback则不能使用这种方式。假如没有commit或rollback的需要,推荐使用这种方式(看来For这种方式有问题)。

修改游标的当前记录的方法

update tb_market_code set market_code='0' where current of cursor1;

但是要注意将cursor1定义为可修改的游标

declare cursor1 cursor for select market_code from tb_market_code
for update;

for update 不能和GROUP BY、 DISTINCT、 ORDER BY、 FOR READ ONLY及UNION, EXCEPT, or INTERSECT但 UNION ALL除外)一起使用。

下一页>>

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

[打印] [关闭]
Google
相关文章
上一篇: 19行js代码击垮iPhone和iPod Touch
下一篇: 主流灾难备份及恢复技术分析
热点关注
IDC资讯 虚拟主机 域名注册 托管租用 vps主机 智能建站
网站运营 建站经验 策划盈利 搜索优化 网站推广 免费资源
网站联盟 联盟新闻 联盟介绍 联盟点评 网赚技巧
行业资讯 业界动态 搜索引擎 网络游戏 门户动态 电子商务 广告传媒
网络编程 Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术 Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷 Internet Explorer
网页制作 FrontPages Dreamweaver Javascript css photoshop fireworks Flash
程序设计 Java技术 C/C++ VB delphi
网络知识 网络协议 网络安全 网络管理 组网方案 Cisco技术
操作系统 Win2000 WinXP Win2003 Mac OS Linux FreeBSD
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 价格总览 | 资讯中心 | 友情链接 | 网站地图 | 招贤纳士 | RSS