溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Postgresql 數據庫中轉義字符

發(fā)布時間:2021-01-29 15:56:55 來源:億速云 閱讀:294 作者:Leah 欄目:開發(fā)技術

這篇文章給大家介紹怎么在Postgresql 數據庫中轉義字符,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

產生問題

Postgresql數據庫運行下面insert命令

insert into mapping_mac_brand(_id,mac,brand) values(777,'D86595','Toy\'s Myth Inc.')

提示下面的警告:

Warning: nonstandard use of \' in a string literal

HINT: Use '' to write quotes in strings or use the escape string syntax(E...')

解決辦法

1.名詞解釋

string literal :字符串字面量

escape string:轉義字符串

escape character:轉義字符

Escape Sequence:轉義字符串

轉義字符:

所有的ASCII碼都可以用“\”加數字(一般是8進制數字)來表示。而C中定義了一些字母前加"\"來表示常見的那些不能顯示的ASCII字符,如\0,\t,\n等,就稱為轉義字符,因為后面的字符,都不是它本來的ASCII字符意思了。

在Java中,不管是String.split(),還是正則表達式,有一些特殊字符需要轉義, 這些字符是 ( [ { / ^ - $ ¦ } ])。

Java中轉義方法為字符前面加上"\\",這樣在split、replaceAll時就不會報錯了; 不過要注意,String.contains()方法不需要轉義。

但是對于下面表格指定的字符,還是一個\即可轉義。比如\n。

2.常見的轉義字符

字母前面加上反斜線"\"來表示那些不能顯示的ASCII字符.稱為轉義字符.如\0,\t,\n等,就稱為轉義字符,因為后面的字符,都不是它本來的ASCII字符意思了。

所有的轉義字符和所對應的意義:

轉義字符

意義

ASCII碼值(十進制)

\a

響鈴(BEL)

007

\b

退格(BS) ,將當前位置移到前一列

008

\f

換頁(FF),將當前位置移到下頁開頭

012

\n

換行(LF) ,將當前位置移到下一行開頭

010

\r

回車(CR) ,將當前位置移到本行開頭

013

\t

水平制表(HT) (跳到下一個TAB位置)

009

\v

垂直制表(VT)

011

\\

代表一個反斜線字符''\'

092

\'

代表一個單引號(撇號)字符

039

\"

代表一個雙引號字符

034

\0

空字符(NULL)

000

\ddd

1到3位八進制數所代表的任意字符

三位八進制

\xhh

1到2位十六進制所代表的任意字符

二位十六進制

3.解決方法

1.修改數據庫配置,讓數據庫支持\作為轉義字符

早期Postgresql普通字符串中的\是作為轉義字符對待的,所以\\最終會認為是\。但是這是不符合SQL標準的,所以在PG 9.1及以后,普通字符串中的\不會被任務是轉義字符,而E'xx\x'中的\才會被當作是轉義字符。

為了使以前的代碼可以在新的PG版本中運行,便有了standard_conforming_strings這個選項,這個選項默認是on,表示按照SQL標準處理字符串,當設置為off時,按照PG的舊版本處理字符串。運行下面命令,開啟這個選項即可:

ALTER ROLE xx IN DATABASE yy SET standard_conforming_strings TO off;

2. 用新版本支持的轉義字符。''或者 E'',將含有轉義的字符串放在單引號里面

'\\' 或者 E'\\'

補充:PG特殊字符的轉義

實例1

imos=# select * from test;
 name 
------
 c_d
 ab
 _b_c
(3 rows)

imos=# select * from test where name like '_b%';
 name 
------
 ab
 _b_c
(2 rows)

imos=# select * from test where name like 'd_b%' escape 'd';
 name 
------
 _b_c
(1 row)
imos=# select * from test where name like '\_b%' ;
 name 
------
 _b_c
(1 row)

關于怎么在Postgresql 數據庫中轉義字符就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI