oracle儲(chǔ)存過(guò)程中,if條件為某變量不等于1,怎么寫
創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)公司,提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);可快速的進(jìn)行網(wǎng)站開發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,是專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
oracle存儲(chǔ)過(guò)程中的if條件判斷的寫法:
比如:
temp varchar2(10) := '10000';
if temp '10000' then
insert into ...
else
update .......
end if;
語(yǔ)句為:
select * from test where instr(concat(name,'xx'),'xn') = 0 來(lái)查詢name字段不等于'xn'的記錄。
或者可以用 select * from test where nvl(name,'xx')'xn' 來(lái)查詢name字段不等于'xn'的記錄。
在Oracle中,
!=
~=
^=
都是不等于號(hào)的意思。都可以使用。
但是奇怪是的, 我想拿出price不是180000的商品時(shí):(price是Number類型的)
SELECT id, name FROM product where price 180000;
執(zhí)行這個(gè)語(yǔ)句時(shí),priceis null 的記錄不出來(lái)。也就是拿不到price是null的商品。必須使用:
SELECT id, name FROM product where price 180000 or price is null;才行。
字符串的字段存在同樣的問(wèn)題。
記?。簄ull只能通過(guò)is null或者is not null來(lái)判斷,其它操作符與null操作都是false。
測(cè)試:select * from test where name'xn'。只能查出name非空的記錄。去掉name'xn'就可以了。這種寫法有問(wèn)題。
然后用了instr(name,'xn')=0 來(lái)判斷,如果name非空的話,判斷還是有效的。如果name為空,這個(gè)判斷又出問(wèn)題了。不得已只得采取instr(concat(name,'xx'),'xn') = 0來(lái)判斷,因?yàn)榫退鉵ame為空,當(dāng)和'xx'連接后,也會(huì)不為空的。
所以最后的sql語(yǔ)句為:
select * from test where instr(concat(name,'xx'),'xn') = 0 來(lái)查詢name字段不等于'xn'的記錄。
或者可以用 select * from test where nvl(name,'xx')'xn' 來(lái)查詢name字段不等于'xn'的記錄。