婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PostgreSQL的中文拼音排序案例

PostgreSQL的中文拼音排序案例

熱門標簽:電話機器人怎么換人工座席 天津開發區地圖標注app 濟南外呼網絡電話線路 廣州電銷機器人公司招聘 地圖標注要花多少錢 移動外呼系統模擬題 江蘇400電話辦理官方 400電話申請客服 電銷機器人能補救房產中介嗎

前一段時間開發人員咨詢,說postgresql里面想根據一個字段做中文的拼音排序,但是不得其解

環境:

OS:CentOS 6.3

DB:PostgreSQL 9.2.4

TABLE: tbl_kenyon

場景:

postgres=# \d tbl_kenyon 
  Table "public.tbl_kenyon"
 Column | Type |  Modifiers  
--------+------+---------------
 vname | text |

--使用排序后的結果,不是很理想

postgres=# select vname from tbl_kenyon order by vname;
 vname 
-------
 上海
 北京
 杭州
 浙江
(4 rows)

說明:

postgresql的排序除了受到數據庫的編碼影響外,還有一個初始化參數是locale也會影響(initdb),,通常我的選擇是C,這可以讓postgres數據庫通過strcmp()這個函數來比較字符串,而不是strcoll()函數。

這個參數可以在數據庫里查看,如

postgres=# \l
                List of databases
   Name    | Owner  | Encoding | Collate | Ctype |  Access privileges  
-----------------+----------+----------+---------+-------+-----------------------
 dkenyon     | u_kenyon | UTF8   | C    | C   | 
 postgres    | postgres | UTF8   | C    | C   | 
 template0    | postgres | UTF8   | C    | C   | =c/postgres     +
         |     |     |     |    | postgres=CTc/postgres
 template1    | postgres | UTF8   | C    | C   | =c/postgres     +
         |     |     |     |    | postgres=CTc/postgres
(6 rows)

--簡體中文在系統表里的支持

postgres=# select collname,collcollate,collctype,b.nspname,c.rolname as collowner 
postgres-# from pg_collation a,pg_namespace b,pg_authid c 
postgres-# where a.collnamespace = b.oid and a.collowner = c.oid and lower(collname) like '%zh_cn%';
  collname  | collcollate | collctype  | nspname  | collowner 
--------------+--------------+--------------+------------+-----------
 zh_CN    | zh_CN    | zh_CN    | pg_catalog | postgres
 zh_CN    | zh_CN.utf8  | zh_CN.utf8  | pg_catalog | postgres
 zh_CN.gb2312 | zh_CN.gb2312 | zh_CN.gb2312 | pg_catalog | postgres
 zh_CN.utf8  | zh_CN.utf8  | zh_CN.utf8  | pg_catalog | postgres
(4 rows)

因為初始化時選擇的locale是C,所以數據庫的默認排序也是C,要想字段內容按照中文拼音排序,需要將UTF8格式存儲的內容轉換為GBK方式。

解決辦法:

1.轉換字段的方式,加個convert_to前綴函數

postgres=# select vname from tbl_kenyon order by convert_to(vname,'GBK');
 vname 
 
-------
 北京
 杭州
 上海
 浙江
(4 rows)

--convert_to函數輸入參數是text形式,輸出編碼是bytea形式,是將字符轉換為目標編碼的函數,如

postgres=# select convert_to('浙江','UTF8'),('浙江','GBK');
  convert_to  |  row   
----------------+------------
 \xe6b599e6b19f | (浙江,GBK)
(1 row)

2.列指定zh_cn的方式存儲

postgres=# alter table tbl_kenyon add cname text collate "zh_CN";
ALTER TABLE
postgres=# \d tbl_kenyon 
  Table "public.tbl_kenyon"
 Column | Type |  Modifiers  
--------+------+---------------
 vname | text | 
 cname | text | collate zh_CN
postgres=# select * from tbl_kenyon;
 vname | cname 
-------+-------
 浙江 | 浙江
 杭州 | 杭州
 上海 | 上海
 北京 | 北京
(4 rows)
postgres=# select * from tbl_kenyon order by vname;
 vname | cname 
-------+-------
 上海 | 上海
 北京 | 北京
 杭州 | 杭州
 浙江 | 浙江
(4 rows)
postgres=# select * from tbl_kenyon order by cname;
 vname | cname 
-------+-------
 北京 | 北京
 杭州 | 杭州
 上海 | 上海
 浙江 | 浙江
(4 rows)

3.查詢時指定collate

postgres=# select * from tbl_kenyon order by vname collate "C";
 vname | cname 
-------+-------
 上海 | 上海
 北京 | 北京
 杭州 | 杭州
 浙江 | 浙江
(4 rows)
postgres=# select * from tbl_kenyon order by vname collate "zh_CN";
 vname | cname 
-------+-------
 北京 | 北京
 杭州 | 杭州
 上海 | 上海
 浙江 | 浙江
(4 rows)

其他問題:

1.在用了方法一的convert_to函數轉換一段時間后,開發告訴我說有異常,報錯 character with byte sequence 0xc2 0xae in encoding "UTF8" has no equivalent in encoding "GBK"

Error querying database. Cause: org.postgresql.util.PSQLException: ERROR: character with byte sequence 0xc2 0xae in
 encoding "UTF8" has no equivalent in encoding "GBK"

排查了一下,發現數據庫里存了一些比較奇怪的字符導致的,比如Mirclereg; city,niwhitereg;town。后對該表重建了一下,用方法二解決,所以convert_to函數使用對一些奇怪的字符轉換時需要注意。

2.對于多音字,仍然會產生一定的歧義,比如重慶,會按Z去排序

上述辦法能滿足大部分漢字的拼音排序,但仍有一些不足。比較理想的解決辦法是對這類基礎數據錄入時就指定拼音規則,或者數據庫里存一份數據的拼音字典來關聯使用。

其他:

使用zh_cn存儲時測試字段大小,未測試取值速度

postgres=# insert into tbl_kenyon select repeat('浙江GDOOASASHOME愛你',5000), repeat('浙江GDOOASASHOME愛你',5000) ;
INSERT 0 1
postgres=# insert into tbl_kenyon select repeat('浙江GDOOASASHOME愛你',50000), repeat('浙江GDOOASASHOME愛你',50000) ;
INSERT 0 1
postgres=# insert into tbl_kenyon select repeat('浙江GDOOASASHOME愛你',100000), repeat('浙江GDOOASASHOME愛你',100000) ;
INSERT 0 1
postgres=# select pg_column_size(cname),pg_column_size(vname) from tbl_kenyon ;
 pg_column_size | pg_column_size 
----------------+----------------
      1410 |      1406
     13769 |     13769
     27506 |     27506
(3 rows)

存儲差異并不大

補充

#高版本可能不支持,或者語法不對?
select * from store order by storename collate 'zh_CN';

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • PostGreSql 判斷字符串中是否有中文的案例
  • 自定義函數實現單詞排序并運用于PostgreSQL(實現代碼)
  • PostgreSQL將數據加載到buffer cache中操作方法
  • 在PostgreSQL中使用ltree處理層次結構數據的方法
  • postgresql 中的時間處理小技巧(推薦)
  • Postgresql限制用戶登錄錯誤次數的實例代碼
  • PostgreSQL用戶登錄失敗自動鎖定的處理方案
  • postgresql影子用戶實踐場景分析
  • 如何使用PostgreSQL進行中文全文檢索

標簽:海西 昭通 榆林 辛集 溫州 杭州 寶雞 濮陽

巨人網絡通訊聲明:本文標題《PostgreSQL的中文拼音排序案例》,本文關鍵詞  PostgreSQL,的,中文,拼音,排序,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL的中文拼音排序案例》相關的同類信息!
  • 本頁收集關于PostgreSQL的中文拼音排序案例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品1区2区在线观看| 日韩亚洲欧美在线| 国产一区二区三区av电影 | 99久久综合色| 成人福利视频在线看| 日韩电影在线观看网站| 一区二区免费看| 国产精品不卡一区二区三区| 国产精品免费免费| 久久精品一区八戒影视| 精品久久国产字幕高潮| 欧美日本韩国一区二区三区视频| 在线观看日韩高清av| 成人精品视频一区二区三区尤物| 国产乱码一区二区三区| 久久不见久久见中文字幕免费| 视频一区二区三区入口| 亚洲成av人影院在线观看网| 日韩伦理av电影| 亚洲午夜视频在线观看| 亚洲女同女同女同女同女同69| 中文字幕一区二区在线观看 | 欧美国产精品专区| 欧美韩国一区二区| 精品国免费一区二区三区| 欧美大片在线观看一区二区| 久久久精品tv| 亚洲欧美另类久久久精品 | 成人性生交大片免费看在线播放| av不卡一区二区三区| 91天堂素人约啪| 欧美天堂亚洲电影院在线播放| 色哟哟一区二区三区| 欧美一区二区视频在线观看| 日韩一区和二区| 日韩欧美国产成人一区二区| 欧美成人艳星乳罩| 国产色综合久久| 亚洲天堂久久久久久久| 亚洲小少妇裸体bbw| 老司机精品视频在线| www.爱久久.com| 欧美亚洲另类激情小说| 国产亚洲欧洲997久久综合 | 精品粉嫩超白一线天av| 国产精品免费视频观看| 亚洲国产精品久久人人爱| 老司机一区二区| 99热在这里有精品免费| 91精品国产91久久综合桃花| 国产日韩精品一区| 亚洲gay无套男同| 国产一区不卡在线| 精品污污网站免费看| 最新国产の精品合集bt伙计| 午夜视频在线观看一区二区三区| 秋霞成人午夜伦在线观看| 色94色欧美sute亚洲13| 国产精品人妖ts系列视频| 日韩一区欧美二区| 91网站最新地址| 337p日本欧洲亚洲大胆精品| 一区二区三区高清| 国产精品综合二区| 欧美日韩国产小视频| 国产精品私人影院| 中文成人综合网| 爽爽淫人综合网网站| 成人深夜在线观看| 欧美三区在线视频| 中文字幕在线一区| 精品在线亚洲视频| 欧美少妇一区二区| 亚洲精品视频免费观看| 亚洲日本一区二区| 日韩国产精品久久| 欧美亚洲国产一区在线观看网站| 国产三级一区二区三区| 日本特黄久久久高潮| 色av一区二区| 中文字幕亚洲综合久久菠萝蜜| 国产成人免费视频网站 | 国产精品久久久久久久岛一牛影视| 欧美国产日产图区| 国产一区视频导航| 久久五月婷婷丁香社区| 日本一区二区三区高清不卡| 麻豆freexxxx性91精品| 欧美在线一区二区| 国产日韩一级二级三级| 国产一区不卡视频| 欧美国产乱子伦 | 日本韩国欧美国产| 欧美日韩免费视频| 亚洲一区二区三区四区在线观看| 91最新地址在线播放| 综合电影一区二区三区| 在线观看亚洲一区| 亚洲精品视频在线观看网站| 欧美日韩国产区一| 日日噜噜夜夜狠狠视频欧美人| 5566中文字幕一区二区电影| 一个色在线综合| 国产河南妇女毛片精品久久久 | 欧美欧美欧美欧美| 中文字幕视频一区| 99免费精品视频| 亚洲免费三区一区二区| 91网站最新地址| 综合久久久久久久| 欧美专区亚洲专区| 日本不卡一二三| 国产喷白浆一区二区三区| 国产成人福利片| 亚洲区小说区图片区qvod| 色中色一区二区| 午夜a成v人精品| 精品国产乱码久久久久久闺蜜| 久久激五月天综合精品| 久久亚洲一级片| 国产剧情一区二区| 日本一区二区视频在线观看| 成人免费观看视频| 天涯成人国产亚洲精品一区av| 欧美三片在线视频观看| 亚洲国产色一区| 日韩一二三四区| 国产精品88av| 中文字幕一区三区| 欧美午夜片在线看| 99国产精品久久久| 国产精品毛片高清在线完整版| 亚洲一区在线观看免费观看电影高清 | 日韩av一级片| 国产精品综合久久| 三级不卡在线观看| 欧美日韩国产一二三| 99国内精品久久| 依依成人综合视频| 欧美三级三级三级| 午夜精品久久久久影视| 精品美女在线播放| 国产精品主播直播| 亚洲成人一区在线| 国产欧美视频一区二区| 99在线视频精品| 亚洲国产人成综合网站| 亚洲欧洲制服丝袜| 欧美夫妻性生活| 91一区二区三区在线观看| 蜜臀av性久久久久蜜臀av麻豆| 日韩一区二区三区高清免费看看 | 亚洲欧洲精品一区二区精品久久久| 成人毛片在线观看| 青青草一区二区三区| 亚洲欧洲一区二区在线播放| 日韩免费性生活视频播放| 色综合夜色一区| 国产美女av一区二区三区| 蜜臂av日日欢夜夜爽一区| 一区二区三区不卡在线观看| 欧美日韩成人激情| 成人黄色免费短视频| 经典一区二区三区| 亚洲图片欧美一区| 亚洲成人av电影在线| 欧美一区二区免费视频| 奇米精品一区二区三区在线观看一| 国产欧美日韩另类一区| 国产精品一区一区| 国产精品全国免费观看高清 | 久久久91精品国产一区二区精品| 99国产精品久久久久久久久久| 毛片av一区二区三区| 亚洲综合小说图片| 夜夜亚洲天天久久| 国产日韩亚洲欧美综合| 日韩欧美国产wwwww| 欧美日韩在线精品一区二区三区激情| 精品一区二区久久| 天堂成人国产精品一区| 亚洲无人区一区| 久久精品99国产精品| 美女国产一区二区| 麻豆91在线播放| 国产69精品一区二区亚洲孕妇| 亚洲国产人成综合网站| 国产欧美va欧美不卡在线| 精品盗摄一区二区三区| 91色在线porny| 欧美视频中文字幕| 日韩一区二区电影网| 蜜臀av性久久久久蜜臀aⅴ流畅 | 日韩av电影免费观看高清完整版| 色婷婷香蕉在线一区二区| 欧美激情一区在线观看| 狠狠色丁香久久婷婷综合_中| 欧美大胆人体bbbb| 日本女人一区二区三区| 欧美日韩精品免费观看视频|