在Oracle中,
創(chuàng)新互聯(lián)公司專注于企業(yè)網(wǎng)絡(luò)營銷推廣、網(wǎng)站重做改版、豐澤網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5網(wǎng)站設(shè)計、電子商務(wù)商城網(wǎng)站建設(shè)、集團公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為豐澤等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
!=
~=
^=
都是不等于號的意思。都可以使用。
但是奇怪是的, 我想拿出price不是180000的商品時:(price是Number類型的)
SELECT id, name FROM product where price 180000;
執(zhí)行這個語句時,priceis null 的記錄不出來。也就是拿不到price是null的商品。必須使用:
SELECT id, name FROM product where price 180000 or price is null;才行。
字符串的字段存在同樣的問題。
記?。簄ull只能通過is null或者is not null來判斷,其它操作符與null操作都是false。
測試:select * from test where name'xn'。只能查出name非空的記錄。去掉name'xn'就可以了。這種寫法有問題。
然后用了instr(name,'xn')=0 來判斷,如果name非空的話,判斷還是有效的。如果name為空,這個判斷又出問題了。不得已只得采取instr(concat(name,'xx'),'xn') = 0來判斷,因為就算name為空,當(dāng)和'xx'連接后,也會不為空的。
所以最后的sql語句為:
select * from test where instr(concat(name,'xx'),'xn') = 0 來查詢name字段不等于'xn'的記錄。
或者可以用 select * from test where nvl(name,'xx')'xn' 來查詢name字段不等于'xn'的記錄。
CREATE OR REPLACE Function Isnumeric(Str In Varchar2)
Return Number
Is
Begin
If Str Is Null
Then
Return 0;
Else
If Regexp_Like(Str, '^(-{0,1}+{0,1})[0-9]+(.{0,1}[0-9]+)$') --數(shù)值
/*(str, '^[0-9]*[1-9][0-9]*$') --正整數(shù)*/
Then
Return 1;
Else
Return 0;
End If;
End If;
End Isnumeric;
創(chuàng)建上面的函數(shù),然后判斷返回值是否是1,1則表示是數(shù)值,0則表示非數(shù)值
SELECT REGEXP_REPLACE('Jeans||Wong', '[|]{2}',) FROM DUAL;
試試,行不行~
數(shù)據(jù)庫中用=或者時是忽略空值的,空值只能通過B is null 或者B is not null設(shè)置條件
網(wǎng)頁題目:oracle怎么表示非 oracle的不等于怎么寫
瀏覽地址:http://www.muchs.cn/article6/hhioog.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、品牌網(wǎng)站建設(shè)、企業(yè)建站、面包屑導(dǎo)航、響應(yīng)式網(wǎng)站、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)