中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

postgresql表中的字段名稱包含特殊符號如何處理

發布時間:2021-01-08 16:23:14 來源:億速云 閱讀:774 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關postgresql表中的字段名稱包含特殊符號如何處理,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

解決方法:

給包含特殊字符的字段加上雙引號"",再進行創建表即可

例如:

create table freighttransport_tab (
 id serial,
 日期 TEXT,
 "重量(公斤)" TEXT
 )

此時"重量(公斤)"字段包含特殊符號(),創建表時,在sql語句中對該字段添加雙引號即可。

補充:PostgreSQL 去除字符串中的不可見字符 終極方法

測試表中數據如下:

postgres=# select * from test;
 street 
----------
 ?澄江街道
 澄江街道
(2 行記錄)

然后我們執行如下sql:

postgres=# select * from test where street='澄江街道';
 street 
----------
 澄江街道
(1 行記錄)

問題已經暴露,明明兩條‘澄江街道'的記錄啊!咋查出來就一條了??

接下來進行如下檢查:

postgres=# select street, length(street) from test;
 street | length 
----------+--------
 ?澄江街道 |  5
 澄江街道 |  4
(2 行記錄)

遇到這種情況就問你懵不懵逼??一樣的字符串長度一個5一個4啊!!日狗,混入不可見字符了。

可能這時已經有人想出了辦法,這種辦法如下:

update test set street='澄江街道' where street like '%澄江街道%';
postgres=# start transaction;
START TRANSACTION
postgres=# update test set street='澄江街道' where street like '%澄江街道%';
UPDATE 2
postgres=# select * from test where street='澄江街道';
 street 
----------
 澄江街道
 澄江街道
(2 行記錄)
 
postgres=# rollback;
ROLLBACK

哈哈,皆大歡喜,問題解決了。

但是,如果這種數據很多呢???

你是要一條一條的update咯??

不幸的是,本人遇到的這種數據就很多(因為數據是從excel中導入進來的)。

然后我就找到了如下這種終極方案:

先確定這種不可見字符到底是哪個字符(一般情況一個csv文件的中如果有不可見字符應該也都是同一個不可見字符)

postgres=# select encode(street::bytea,'escape') from test;
       encode       
--------------------------------------------------------------
 \357\273\277\346\276\204\346\261\237\350\241\227\351\201\223
 \346\276\204\346\261\237\350\241\227\351\201\223
(2 行記錄)

那段\357\273\277多刺眼啊。。。。。。

如果你有仇人可以考慮有這種方法報復他了

然后確定是否可以將該不可見字符過濾掉:

postgres=# select encode(street::bytea,'escape') from test where btrim(street::bytea,E'\\357\\273\\277'::bytea) = '澄江街道';
       encode       
--------------------------------------------------------------
 \357\273\277\346\276\204\346\261\237\350\241\227\351\201\223
 \346\276\204\346\261\237\350\241\227\351\201\223
(2 行記錄)

查到了兩條記錄,用這個btrim看來確實是把字符串里的\357\273\277全部去除了。

接下來就要update表啦~

postgres=# update test set street=btrim(street::bytea,E'\\357\\273\\277'::bytea);
UPDATE 2

update成功。

查看數據:

postgres=# select * from test;
   street   
----------------------------
 \xe6be84e6b19fe8a197e98193
 \xe6be84e6b19fe8a197e98193
(2 行記錄)

哈哈,中文變成16進制的了。

不過不用捉急。

postgres=# select convert_from(street::bytea,'UTF8') from test;
 convert_from 
--------------
 澄江街道
 澄江街道
(2 行記錄)

再轉回UTF8編碼不就行了?(亂碼問題是所有問題中最簡單的問題,沒有之一)

按照這種方法update一下表:

postgres=# update test set street=convert_from(street::bytea,'UTF8');
UPDATE 2
postgres=# select * from test;
 street 
----------
 澄江街道
 澄江街道
(2 行記錄)

正常的數據又回來啦。

postgres=# select * from test where street='澄江街道';
 street 
----------
 澄江街道
 澄江街道
(2 行記錄)
 
postgres=# select street, length(street) from test;
 street | length 
----------+--------
 澄江街道 |  4
 澄江街道 |  4
(2 行記錄)

上述就是小編為大家分享的postgresql表中的字段名稱包含特殊符號如何處理了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

顺平县| 新干县| 伽师县| 大余县| 贵港市| 江北区| 县级市| 延长县| 金阳县| 嘉鱼县| 崇义县| 蒲城县| 大冶市| 吉林市| 成都市| 海城市| 略阳县| 曲周县| 嵩明县| 望都县| 淳安县| 凌云县| 汉阴县| 丰台区| 平安县| 静宁县| 志丹县| 天祝| 崇阳县| 万州区| 铜梁县| 化州市| 甘德县| 梅州市| 固始县| 古蔺县| 夏津县| 高邑县| 遵义县| 柳林县| 清远市|