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除外)一起使用。
1.5 類似decode的轉碼操作
oracle中有一個函數 select decode(a1,’1’,’n1’,’2’,’n2’,’n3’) aa1 from
db2沒有該函數,但可以用變通的方法
select case a1
when ’1’ then ’n1’
when ’2’ then ’n2’
else ’n3’
end as aa1 from
1.6 類似charindex查找字符在字串中的位置
Locate(‘y','dfdasfay')
查找'y' 在'dfdasfay'中的位置。
1.7 類似datedif計算兩個日期的相差天數
days(date(‘2001-06-05')) – days
DB2編程序技巧(1)
2020-06-09 18:14數據庫之家 DB2
本文主要講解DB2編程序技巧(1),具有一定的參考價值,有需要的朋友可以參考一下。
延伸 · 閱讀
- 2022-03-03C語言趣味編程之平分七筐魚
- 2022-03-03C#面向對象編程基礎概念匯總
- 2022-03-02分享 18 個 Python 高效編程技巧
- 2022-03-01Linux Socket 編程簡介和實現
- 2022-03-01詳解易語言編程原理和方法
- 2022-02-27Linux多線程編程快速入門
- DB2
DB2專家王云談商業智能BI
王云說: 既然講商業智能,我們大家都在講及時性,我們講要有績效,要有BPM,我自己就來看看我們能不能在這個會場上,我們來實踐一下,如果大家抬頭...
- DB2
DB2 UDB V8.1管理學習筆記(三)
本文主要講解DB2 UDB V8.1管理學習筆記(三),有需要的朋友可以參考下 ...
- DB2
CentOS下DB2數據庫安裝過程詳解
這篇文章主要介紹了CentOS下DB2數據庫安裝過程詳解,本文步驟詳細,操作的命令也比較全,需要的朋友可以參考下 ...
- DB2
db2數據庫常用操作命令大全
這篇文章主要介紹了db2數據庫常用操作命令大全,匯總了DB2的常用操作命令,分享給大家供大家參考,需要的朋友可以參考下...
- DB2
如何訪問大型機、小型機上的DB2 9數據服務器
數據庫連接工具軟件 DB2 connect的基本特性是為桌面應用程序和服務主機的數據庫服務器之間提供一種連接交互訪問的方法。這些桌面應用程序所在的環境可...
- DB2
python之sqlalchemy創建表的實例詳解
這篇文章主要介紹了數據庫之sqlalchemy創建表的實例詳解的相關資料,希望通過本文能幫助到大家,讓大家掌握理解這部分內容,需要的朋友可以參考下...
- DB2
分析DB2活動日志滿的原因及解決DB2日志滿方法與避免方案
本文簡單地介紹了DB2中日志的使用、活動日志以及首個活動日志的概念、日志滿的原因、日志滿的診斷、臨時處理以及避免辦法 ...
- DB2
DB2 SELECT語句高級用法
DB2 SELECT語句高級用法,學習db2數據庫的朋友可以參考下。 ...