理解collate Chine_PRC_CI_AS

更新时间:2023-07-07 17:24:24 阅读: 评论:0

理解collate Chine_PRC_CI_AS
我们在create table时经常会碰到这样的语句,例如:password nvarchar(10)collate chine_prc_ci_as null,那它到底是什么意思呢?不妨看看下面:
首先,collate是一个子句,可应用于数据库定义或列定义以定义排序规则,或应用于字符串表达式以应用排序规则投影。
语法是collate collation_name
japane young girl
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支持的所有排序规则。
    lect * from ::fn_helpcollations()
排序规则名称由两部份构成,前半部份是指本排序规则所支持的字符集。
如:
  Chine_PRC_CS_AI_WS
前半部份:指UNICODE字符集,Chine_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 Chine_PRC_CI_AI_WS,   
value int )
表建好后,执行连接查询:
lect * from #t1 A inner join #t2 B on A.name=B.name
这样,错误就出现了:
          服务器: 消息 446,级别 16,状态 9,行 1
          无法解决 equal to 操作的排序规则冲突。
  要排除这个错误,最简单方法是,表连接时指定它的排序规则,这样错误就
不再出现了。语句这样写:
lect *
from #t1 A inner join #t2 B
on A.name=B.name collate Chine_PRC_CI_AI_WS

二.排序规则简介:
北京市翻译公司    什么叫排序规则呢?MS是这样描述的:"在 Microsoft SQL Server 2000 中,
字符串的物理存储由排序规则控制。排序规则指定表示每个字符的位模式以及存
储和比较字符所使用的规则。"
  在查询分析器内执行下面语句,可以得到SQL SERVER支持的所有排序规则。
    lect * from ::fn_helpcollations()
排序规则名称由两部份构成,前半部份是指本排序规则所支持的字符集。
如:
  Chine_PRC_CS_AI_WS
前半部份:指UNICODE字符集,Chine_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列的内容按拼音排序:2020年7月六级真题及答案
create table #t(id int,name varchar(20))
inrt #t lect 1,'中'
union all lect 2,'国'
union all lect 3,'人'
union all lect 4,'阿'
lect * from #t order by name collate Chine_PRC_CS_AS_KS_WS
drop table #t
/*结果:
id          name               
----------- --------------------
4          阿
2          国
3          人
1          中
*/
  例2:让表NAME列的内容按姓氏笔划排序:
机械英语翻译
create table #t(id int,name varchar(20))
inrt #t lect 1,'三'
union all lect 2,'乙'
union all lect 3,'二'
union all lect 4,'一'
union all lect 5,'十'
lect * from #t order by name collate Chine_PRC_Stroke_CS_AS_KS_WS 
drop table #t
/*结果:
id          name               
----------- --------------------
4          一
2          乙
3          二
homely5          十
1          三
*/company是什么意思
四.在实践中排序规则应用的扩展
  SQL SERVER汉字排序规则可以按拼音、笔划等排序,那么我们如何利用这种功能
惊喜的英文怎么读来处理汉字的一些难题呢?我现在举个例子:
          用排序规则的特性计算汉字笔划
  要计算汉字笔划,我们得先做准备工作,我们知道,WINDOWS多国汉字,UNICODE目前自考准考证号查询
收录汉字共20902个。简体GBK码汉字UNICODE值从19968开始。
  首先,我们先用SQLSERVER方法得到所有汉字,不用字典,我们简单利用SQL语句就
可以得到:

本文发布于:2023-07-07 17:24:24,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/90/170163.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:排序   规则   区分   语句
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图