青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

c++的海洋很寬,但我喜歡在里面劃船!

C++博客 首頁 新隨筆 聯系 聚合 管理
  4 Posts :: 0 Stories :: 14 Comments :: 0 Trackbacks
這篇文章出自-----http://hi.baidu.com/hbjinzhao/blog/item/f2c3e919014f0a7cdab4bd94.html

我們在create table時經常會碰到這樣的語句,例如:password nvarchar(10)collate chinese_prc_ci_as null,那它到底是什么意思呢?不妨看看下面:

首先,collate是一個子句,可應用于數據庫定義或列定義以定義排序規則,或應用于字符串表達式以應用排序規則投影。

語法是collate collation_name

collation_name ::={windows_collation_name}|{sql_collation_name}

參數collate_name是應用于表達式、列定義或數據庫定義的排序規則的名稱。collation_name 可以只是指定的 Windows_collation_name SQL_collation_name

Windows_collation_name Windows 排序規則的排序規則名稱。參見 Windows 排序規則名稱。
SQL_collation_name
SQL 排序規則的排序規則名稱。參見 SQL 排序規則名稱。

下面簡單介紹一下排序規則:

什么叫排序規則呢?MS是這樣描述的:" Microsoft SQL Server 2000 中,
字符串的物理存儲由排序規則控制。排序規則指定表示每個字符的位模式以及存
儲和比較字符所使用的規則。"
  在查詢分析器內執行下面語句,可以得到SQL SERVER支持的所有排序規則。

    select * from ::fn_helpcollations()

排序規則名稱由兩部份構成,前半部份是指本排序規則所支持的字符集。
如:
  Chinese_PRC_CS_AI_WS
前半部份:指UNICODE字符集,Chinese_PRC_指針對大陸簡體字UNICODE的排序規則。
排序規則的后半部份即后綴 含義:
  _BIN 二進制排序
  _CI(CS) 是否區分大小寫,CI不區分,CS區分
  _AI(AS) 是否區分重音,AI不區分,AS區分   
  _KI(KS) 是否區分假名類型,KI不區分,KS區分 
     _WI(WS)
是否區分寬度 WI不區分,WS區分 

區分大小寫:如果想讓比較將大寫字母和小寫字母視為不等,請選擇該選項。
區分重音:如果想讓比較將重音和非重音字母視為不等,請選擇該選項。如果選擇該選項,
        
比較還將重音不同的字母視為不等。
區分假名:如果想讓比較將片假名和平假名日語音節視為不等,請選擇該選項。
區分寬度:如果想讓比較將半角字符和全角字符視為不等,請選擇該選項


利用排序規則特點計算漢字筆劃和取得拼音首字母

SQL SERVER的排序規則平時使用不是很多,也許不少初學者還比較陌生,但有
一個錯誤大家應是經常碰到: SQL SERVER數據庫,在跨庫多表連接查詢時,若兩數據
庫默認字符集不同,系統就會返回這樣的錯誤:
      
           “無法解決 equal to 操作的排序規則沖突。”

一.錯誤分析:
  這個錯誤是因為排序規則不一致造成的,我們做個測試,比如:
create table #t1(
name varchar(20) collate Albanian_CI_AI_WS,  
value int)

create table #t2(
name varchar(20) collate Chinese_PRC_CI_AI_WS,    
value int )

表建好后,執行連接查詢:

select * from #t1 A inner join #t2 B on A.name=B.name

這樣,錯誤就出現了:

           服務器: 消息 446,級別 16,狀態 9,行 1
           無法解決 equal to 操作的排序規則沖突。
  要排除這個錯誤,最簡單方法是,表連接時指定它的排序規則,這樣錯誤就
不再出現了。語句這樣寫:

select *
from #t1 A inner join #t2 B
on A.name=B.name collate Chinese_PRC_CI_AI_WS


二.排序規則簡介:

     什么叫排序規則呢?MS是這樣描述的:"在 Microsoft SQL Server 2000 中,
字符串的物理存儲由排序規則控制。排序規則指定表示每個字符的位模式以及存
儲和比較字符所使用的規則。"
  在查詢分析器內執行下面語句,可以得到SQL SERVER支持的所有排序規則。

    select * from ::fn_helpcollations()

排序規則名稱由兩部份構成,前半部份是指本排序規則所支持的字符集。
如:
  Chinese_PRC_CS_AI_WS
前半部份:指UNICODE字符集,Chinese_PRC_指針對大陸簡體字UNICODE的排序規則。
排序規則的后半部份即后綴 含義:
  _BIN 二進制排序
  _CI(CS) 是否區分大小寫,CI不區分,CS區分
  _AI(AS) 是否區分重音,AI不區分,AS區分   
  _KI(KS) 是否區分假名類型,KI不區分,KS區分 
     _WI(WS) 是否區分寬度 WI不區分,WS區分 

區分大小寫:如果想讓比較將大寫字母和小寫字母視為不等,請選擇該選項。
區分重音:如果想讓比較將重音和非重音字母視為不等,請選擇該選項。如果選擇該選項,
         比較還將重音不同的字母視為不等。
區分假名:如果想讓比較將片假名和平假名日語音節視為不等,請選擇該選項。
區分寬度:如果想讓比較將半角字符和全角字符視為不等,請選擇該選項


三.排序規則的應用:
  SQL SERVER提供了大量的WINDOWS和SQLSERVER專用的排序規則,但它的應用往往
被開發人員所忽略。其實它在實踐中大有用處。

  例1:讓表NAME列的內容按拼音排序:

create table #t(id int,name varchar(20))
insert #t select 1,'中'
union all select 2,'國'
union all select 3,'人'
union all select 4,'阿'

select * from #t order by name collate Chinese_PRC_CS_AS_KS_WS
drop table #t
/*結果:
id           name                
----------- --------------------
4           阿
2           國
3           人
1           中
*/

  例2:讓表NAME列的內容按姓氏筆劃排序:

create table #t(id int,name varchar(20))

insert #t select 1,'三'
union all select 2,'乙'
union all select 3,'二'
union all select 4,'一'
union all select 5,'十'
select * from #t order by name collate Chinese_PRC_Stroke_CS_AS_KS_WS  
drop table #t
/*結果:
id           name                
----------- --------------------
4           一
2           乙
3           二
5           十
1           三
*/

四.在實踐中排序規則應用的擴展
  SQL SERVER漢字排序規則可以按拼音、筆劃等排序,那么我們如何利用這種功能
來處理漢字的一些難題呢?我現在舉個例子:

          用排序規則的特性計算漢字筆劃

  要計算漢字筆劃,我們得先做準備工作,我們知道,WINDOWS多國漢字,UNICODE目前
收錄漢字共20902個。簡體GBK碼漢字UNICODE值從19968開始。
  首先,我們先用SQLSERVER方法得到所有漢字,不用字典,我們簡單利用SQL語句就
可以得到:

select top 20902 code=identity(int,19968,1) into #t from syscolumns a,syscolumns b

再用以下語句,我們就得到所有漢字,它是按UNICODE值排序的:

  select code,nchar(code) as CNWord from #t

  然后,我們用SELECT語句,讓它按筆劃排序。

select code,nchar(code) as CNWord
from #t
order by nchar(code) collate Chinese_PRC_Stroke_CS_AS_KS_WS,code

結果:
code         CNWord
----------- ------
19968       一
20008       丨
20022       丶
20031       丿
20032       乀
20033       乁
20057       乙
20058       乚
20059       乛
20101       亅
19969       丁
..........

    從上面的結果,我們可以清楚的看到,一筆的漢字,code是從19968到20101,從小到大排,但到
了二筆漢字的第一個字“丁”,CODE為19969,就不按順序而重新開始了。有了這結果,我們就可以輕
松的用SQL語句得到每種筆劃漢字歸類的第一個或最后一個漢字。
下面用語句得到最后一個漢字:

create table #t1(id int identity,code int,cnword nvarchar(2))

insert #t1(code,cnword)
select code,nchar(code) as CNWord   from #t
order by nchar(code) collate Chinese_PRC_Stroke_CS_AS_KS_WS,code


select A.cnword
from #t1 A
left join #t1 B on A.id=B.id-1 and A.code
where B.code is null
order by A.id

得到36個漢字,每個漢字都是每種筆劃數按Chinese_PRC_Stroke_CS_AS_KS_WS排序規則排序后的
最后一個漢字:

亅阝馬風龍齊龜齒鴆齔龕龂齠齦齪龍龠龎龐龑龡龢龝齹龣龥齈龞麷鸞麣龖龗齾齉龘

  上面可以看出:“亅”是所有一筆漢字排序后的最后一個字,“阝”是所有二筆漢字排序后的最后
一個字......等等。
  但同時也發現,從第33個漢字“龗(33筆)”后面的筆劃有些亂,不正確。但沒關系,比“龗”筆劃
多的只有四個漢字,我們手工加上:齾35筆,齉36筆,靐39筆,龘64筆

建漢字筆劃表(TAB_HZBH):
create table tab_hzbh(id int identity,cnword nchar(1))
--先插入前33個漢字
insert tab_hzbh
select top 33 A.cnword
from #t1 A
left join #t1 B on A.id=B.id-1 and A.code
where B.code is null
order by A.id
--再加最后四個漢字
set identity_insert tab_hzbh on
go
insert tab_hzbh(id,cnword)
     select 35,N'齾'
union all select 36,N'齉'
union all select 39,N'靐'
union all select 64,N'龘'
go
set identity_insert tab_hzbh off
go

  到此為止,我們可以得到結果了,比如我們想得到漢字“國”的筆劃:

declare @a nchar(1)
set @a='國'
select top 1 id
from   tab_hzbh
where cnword>=@a collate Chinese_PRC_Stroke_CS_AS_KS_WS
order by id

id          
-----------
8
(結果:漢字“國”筆劃數為8)

  上面所有準備過程,只是為了寫下面這個函數,這個函數撇開上面建的所有臨時表和固
定表,為了通用和代碼轉移方便,把表tab_hzbh的內容寫在語句內,然后計算用戶輸入一串
漢字的總筆劃:

create function fun_getbh(@str nvarchar(4000))
returns int
as
begin
declare @word nchar(1),@n int
set @n=0
while len(@str)>0
begin
set @word=left(@str,1)
--如果非漢字,筆劃當0計
set @n=@n+(case when unicode(@word) between 19968 and 19968+20901
then (select top 1 id from (
select 1 as id,N'亅' as word
union all select 2,N'阝'
union all select 3,N'馬'
union all select 4,N'風'
union all select 5,N'龍'
union all select 6,N'齊'
union all select 7,N'龜'
union all select 8,N'齒'
union all select 9,N'鴆'
union all select 10,N'齔'
union all select 11,N'龕'
union all select 12,N'龂'
union all select 13,N'齠'
union all select 14,N'齦'
union all select 15,N'齪'
union all select 16,N'龍'
union all select 17,N'龠'
union all select 18,N'龎'
union all select 19,N'龐'
union all select 20,N'龑'
union all select 21,N'龡'
union all select 22,N'龢'
union all select 23,N'龝'
union all select 24,N'齹'
union all select 25,N'龣'
union all select 26,N'龥'
union all select 27,N'齈'
union all select 28,N'龞'
union all select 29,N'麷'
union all select 30,N'鸞'
union all select 31,N'麣'
union all select 32,N'龖'
union all select 33,N'龗'
union all select 35,N'齾'
union all select 36,N'齉'
union all select 39,N'靐'
union all select 64,N'龘'
) T
where word>=@word collate Chinese_PRC_Stroke_CS_AS_KS_WS
order by id ASC) else 0 end)
set @str=right(@str,len(@str)-1)
end
return @n
end

--函數調用實例:
select dbo.fun_getbh('中華人民共和國'),dbo.fun_getbh('中華人民共和國')
 
  執行結果:筆劃總數分別為39和46,簡繁體都行。

     當然,你也可以把上面“UNION ALL”內的漢字和筆劃改存在固定表內,在漢字
列建CLUSTERED INDEX,列排序規則設定為:
    Chinese_PRC_Stroke_CS_AS_KS_WS
這樣速度更快。如果你用的是BIG5碼的操作系統,你得另外生成漢字,方法一樣。
但有一點要記住:這些漢字是通過SQL語句SELECT出來的,不是手工輸入的,更不
是查字典得來的,因為新華字典畢竟不同于UNICODE字符集,查字典的結果會不正
確。

  
               用排序規則的特性得到漢字拼音首字母

  用得到筆劃總數相同的方法,我們也可以寫出求漢字拼音首字母的函數。如下:

create function fun_getPY(@str nvarchar(4000))
returns nvarchar(4000)
as
begin
declare @word nchar(1),@PY nvarchar(4000)
set @PY=''
while len(@str)>0
begin
set @word=left(@str,1)
--如果非漢字字符,返回原字符
set @PY=@PY+(case when unicode(@word) between 19968 and 19968+20901
then (select top 1 PY from (
select 'A' as PY,N'驁' as word
union all select 'B',N'簿'
union all select 'C',N'錯'
union all select 'D',N'鵽'
union all select 'E',N'樲'
union all select 'F',N'鰒'
union all select 'G',N'腂'
union all select 'H',N'夻'
union all select 'J',N'攈'
union all select 'K',N'穒'
union all select 'L',N'鱳'
union all select 'M',N'旀'
union all select 'N',N'桛'
union all select 'O',N'漚'
union all select 'P',N'曝'
union all select 'Q',N'囕'
union all select 'R',N'鶸'
union all select 'S',N'蜶'
union all select 'T',N'籜'
union all select 'W',N'鶩'
union all select 'X',N'鑂'
union all select 'Y',N'韻'
union all select 'Z',N'咗'
) T
where word>=@word collate Chinese_PRC_CS_AS_KS_WS
order by PY ASC) else @word end)
set @str=right(@str,len(@str)-1)
end
return @PY
end

--函數調用實例:
select dbo.fun_getPY('中華人民共和國'),dbo.fun_getPY('中華人民共和國')
結果都為:ZHRMGHG

posted on 2009-10-09 19:58 星星點燈 閱讀(499) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产日韩欧美不卡| 亚洲精品日日夜夜| 韩国精品在线观看| 国产噜噜噜噜噜久久久久久久久 | 亚洲黄色一区| 亚洲激情偷拍| 午夜精彩国产免费不卡不顿大片| 亚洲激情综合| 日韩视频久久| 亚洲精品一区久久久久久| 在线观看av不卡| 一区二区三欧美| 美女脱光内衣内裤视频久久影院 | 亚洲欧美日韩一区二区在线| 亚洲女女做受ⅹxx高潮| 久久综合色播五月| 亚洲乱码国产乱码精品精| 亚洲欧美日韩视频二区| 欧美中文字幕视频在线观看| 欧美福利视频网站| 影音先锋久久精品| 亚洲在线免费观看| 欧美不卡三区| 日韩午夜在线视频| 欧美日本中文字幕| 国产精品你懂的在线| 国产欧美日韩亚洲精品| 国产乱人伦精品一区二区| 亚洲福利国产| 午夜欧美精品| 日韩视频在线观看| 欧美一区二区视频97| 欧美日韩国语| 亚洲久久在线| 开心色5月久久精品| 亚洲美女中出| 欧美日韩国产影院| 一区二区三区视频观看| 一区二区三区欧美成人| 欧美日韩一区二区三区四区在线观看| 国产精品区一区二区三区| 亚洲日本免费| 99精品免费| 国产精品一区二区久久久久| 亚洲欧美另类综合偷拍| aa国产精品| 国产精品爱久久久久久久| 在线亚洲一区观看| 亚洲制服丝袜在线| 韩日午夜在线资源一区二区| 欧美福利一区| 国产一区二区三区在线观看网站| 久久精品国产一区二区电影 | 9i看片成人免费高清| 亚洲高清不卡| 久久国产精品亚洲77777| 国产精品www.| 亚洲第一黄色网| 欧美va天堂| 亚洲午夜精品国产| 亚洲一二三区在线观看| 一区二区视频免费在线观看| 亚洲片在线资源| 国产精品免费区二区三区观看| 欧美亚洲一区二区在线| 久久综合给合| 久久综合伊人77777尤物| 欧美性淫爽ww久久久久无| 欧美一区二区在线播放| 欧美日韩精品久久久| 亚洲国产一区二区三区高清 | 在线亚洲电影| 欧美成人免费小视频| 快播亚洲色图| 国产丝袜一区二区| 亚洲欧美精品在线观看| 亚洲精品免费看| 欧美激情性爽国产精品17p| 另类激情亚洲| 91久久精品国产91久久| 免费欧美高清视频| 亚洲美女色禁图| 亚洲午夜精品一区二区三区他趣| 欧美岛国激情| 亚洲国产成人精品女人久久久 | 女同一区二区| 亚洲人成在线播放| 亚洲自拍偷拍网址| 国内成+人亚洲| 美国成人直播| 亚洲曰本av电影| 亚洲一区二区精品| 在线中文字幕一区| 一区二区三区www| 亚洲日本在线视频观看| 牛牛影视久久网| 欧美成人免费大片| 亚洲国产成人porn| 99国产精品视频免费观看一公开 | 亚洲午夜视频| 亚洲素人一区二区| 午夜在线一区二区| 久久久久久一区| 欧美久久一区| 国产精品一区免费视频| 国产亚洲精品久久久久动| 国外成人在线视频| 亚洲另类自拍| 久久噜噜亚洲综合| 亚洲激情午夜| 国产日产欧美a一级在线| 亚洲国产精品久久人人爱蜜臀| 午夜精品福利在线观看| 亚洲免费大片| 久久精品噜噜噜成人av农村| 亚洲啪啪91| 看片网站欧美日韩| 国产日韩欧美一区在线| 亚洲精品久久久久久下一站| 欧美成人亚洲成人| 久久精品欧洲| 女人香蕉久久**毛片精品| 国产自产精品| 午夜国产精品影院在线观看| 亚洲福利视频二区| 欧美大尺度在线| 影音先锋中文字幕一区| 玖玖国产精品视频| 老司机精品视频一区二区三区| 亚洲第一区在线| 最新日韩欧美| 国产精品蜜臀在线观看| 亚洲精品乱码| 老司机午夜精品| 久久av一区| 国产一区日韩欧美| 欧美在线视频免费| 中文在线资源观看网站视频免费不卡 | 伊人色综合久久天天| 中文精品视频一区二区在线观看| 老巨人导航500精品| 欧美自拍偷拍| 国产精品美女www爽爽爽| 一区二区三区精品国产| 亚洲精品中文字| 欧美激情综合在线| 日韩写真在线| 亚洲视屏一区| 好男人免费精品视频| 久久这里有精品视频| 久久久久久久久久久成人| 在线观看成人小视频| 欧美激情五月| 国产精品久久久久久久久动漫| 亚洲欧美综合| 美乳少妇欧美精品| 亚洲综合视频1区| 久久国产精品久久w女人spa| 91久久精品国产91久久性色tv | 亚洲午夜精品一区二区三区他趣 | 国产精品久久| 久久久久久久999精品视频| 美日韩精品免费| 欧美中文在线观看| 免费在线欧美视频| 久久精品国产精品| 欧美日韩精品免费| 亚洲黄色av| 伊人久久大香线| 99香蕉国产精品偷在线观看| 欧美亚州韩日在线看免费版国语版| 午夜老司机精品| 欧美日韩视频在线一区二区观看视频| 久久精品视频导航| 国产精品theporn| 亚洲毛片播放| 亚洲国产精品一区二区尤物区| 欧美亚洲色图校园春色| 亚洲一区二区三区精品动漫| 欧美刺激午夜性久久久久久久| 欧美激情一区在线观看| 伊人男人综合视频网| 亚洲欧美一区二区视频| 亚洲欧美大片| 国产欧美精品日韩区二区麻豆天美 | 亚洲欧美日韩国产综合| 先锋影音网一区二区| 欧美日韩在线视频观看| 日韩午夜在线播放| 亚洲视频欧美视频| 欧美色视频日本高清在线观看| aa级大片欧美| 久久精品国产99| 18成人免费观看视频| 欧美日韩天天操| 亚洲欧美精品suv| 亚洲高清视频在线| 亚洲综合色婷婷| 91久久精品一区| 国产精品日韩欧美一区二区三区|