begin
創(chuàng)新互聯(lián)為企業(yè)級(jí)客戶提高一站式互聯(lián)網(wǎng)+設(shè)計(jì)服務(wù),主要包括網(wǎng)站制作、成都網(wǎng)站制作、App定制開發(fā)、小程序開發(fā)、宣傳片制作、LOGO設(shè)計(jì)等,幫助客戶快速提升營(yíng)銷能力和企業(yè)形象,創(chuàng)新互聯(lián)各部門都有經(jīng)驗(yàn)豐富的經(jīng)驗(yàn),可以確保每一個(gè)作品的質(zhì)量和創(chuàng)作周期,同時(shí)每年都有很多新員工加入,為我們帶來大量新的創(chuàng)意。
dbms_output.put_line('''abcd''');
end;
oracle中字符串中,單引號(hào)用兩個(gè)單引代表一個(gè),也就是說單引號(hào)本身是轉(zhuǎn)義符
額……比方說……像下面這個(gè):create or replace function fun_get_bookinfo(key_words varchar2(10)) returns table(……)return table (select * from v_book_info where bookname like '/_%' key_words '/');like后面與字符串匹配,但是要用到傳進(jìn)來的參數(shù)直接引號(hào)括起來不就不能傳參了么,是應(yīng)該上面那樣寫么……
一、符號(hào)的處理方案
1、在前面加上語句set define off
首先要理解是做什么的,這個(gè)符合在Oracle中表示替代變量,執(zhí)行時(shí)會(huì)提示用戶輸入,然后以及后面的字符會(huì)替換為用戶輸入的字符。
set define off的作用是關(guān)閉替代變量功能。當(dāng)然你還可以把替代變量改為其它符號(hào),比如改為*號(hào),輸入這個(gè)命令:set define *
2、在SQL語句中將分拆并替換成chr(38)
38是的ASCII碼,實(shí)例sql
3、分拆出號(hào),這也是最簡(jiǎn)單直接的方法
二、符號(hào)'的處理方案
1、直接轉(zhuǎn)義
2、分拆轉(zhuǎn)義
3、分拆并替換成chr(39)
在ORACLE中,單引號(hào)有兩個(gè)作用: 1:字符串是由單引號(hào)引用 2:轉(zhuǎn)義。 單引號(hào)的使用是就近配對(duì),即就近原則。而在單引號(hào)充當(dāng)轉(zhuǎn)義角色時(shí)相對(duì)不好理解1.從第二個(gè)單引號(hào)開始被視為轉(zhuǎn)義符,如果第二個(gè)單引號(hào)后面還有單引號(hào)(哪怕只有一個(gè))。
在字段里查找'%',涉及到Oracle的轉(zhuǎn)義字符,現(xiàn)總結(jié)如下:
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
已選擇9行。
其中包含特殊的字符分別為%,_,,有可能包含這些字符的數(shù)據(jù)含有錯(cuò)誤,或者需要查找包含這些字符的數(shù)據(jù)。
SQL select * from test where test like 'sdd _%' escape ' ';
TEST
--------------------
sdd_kk
轉(zhuǎn)義字符為' ';
SQL select * from test where test like 'sdd\_%' escape '\';
TEST
--------------------
sdd_kk
轉(zhuǎn)義字符為'\';
SQL select * from test where test like 'sdd=_%' escape '=';
TEST
--------------------
sdd_kk
轉(zhuǎn)義字符為'=';
SQL select * from test where test like 'sdd/_%' escape '/';
TEST
--------------------
sdd_kk
轉(zhuǎn)義字符為'/';
SQL select * from test where test like 'sddd_%' escape 'd';
未選定行
轉(zhuǎn)義字符為d,沒有實(shí)現(xiàn)轉(zhuǎn)義功能;
SQL select * from test where test like '%\_%' escape '\';
TEST
--------------------
sdd_kk
查找包含所有'_'的字段。
同理:通過這種方法查找含有'%'的所有字段:
SQL select * from test where test like '%\%%' escape '\';
TEST
--------------------
dffa%asfs
1%2345
1%54321
2%54321
%%54321
但是''不能通過轉(zhuǎn)義字符查找:
SQL select * from test where test like '%\%' escape'\';
select * from test where test like '%\%' escape'\'
*
第 1 行出現(xiàn)錯(cuò)誤:
ORA-01424: 轉(zhuǎn)義符之后字符缺失或非法
可以通過另外的方式進(jìn)行轉(zhuǎn)義:
SQL select ascii('') from dual;
ASCII('')
----------
38
SQL select * from test where test like '%'||chr(38)||'%';
TEST
--------------------
AB
'''的轉(zhuǎn)義:
SQL select * from test where test like '%''%';
TEST
--------------------
d'd
特殊符號(hào)的數(shù)據(jù)的插入
SQL insert into test values('testtest');
輸入 test 的值: test
原值 1: insert into test values('testtest')
新值 1: insert into test values('testtest') -雖然插入,但是數(shù)據(jù)不對(duì)。
已創(chuàng)建 1 行。
SQL show define
define "" (hex 26)
SQL set define off
SQL show define
define OFF
SQL insert into test values('testtest');
已創(chuàng)建 1 行。
SQL show escape
escape OFF
SQL set escape on
SQL show escape
escape "\" (hex 5c)
SQL insert into test values('test\test');
已創(chuàng)建 1 行。
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
testtest
TEST
--------------------
testtest
testtest
已選擇13行。
SQL commit;
提交完成。
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
testtest
TEST
--------------------
testtest
testtest
已選擇13行。
SQL insert into test values('test\%test');
已創(chuàng)建 1 行。
SQL insert into test values('test\_test');
已創(chuàng)建 1 行。
SQL insert into test values('test\'test);
insert into test values('test'test)
*
第 1 行出現(xiàn)錯(cuò)誤:
ORA-00917: 缺失逗號(hào)
SQL insert into test values('test''test');
已創(chuàng)建 1 行。
SQL select * from test;
TEST
--------------------
sdd_kk
d'd
dfsfsa
dffa%asfs
12345
1%2345
1%54321
2%54321
%%54321
AB
testtest
TEST
--------------------
testtest
testtest
test%test
test_test
test'test
已選擇16行。
名稱欄目:oracle括號(hào)怎么轉(zhuǎn)義 oracle 別名帶括號(hào)
分享URL:http://m.newbst.com/article38/hpdopp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、App設(shè)計(jì)、做網(wǎng)站、網(wǎng)站營(yíng)銷、云服務(wù)器、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)