MSSQL SQL语句区分大小写问题

原创 2007年09月26日 14:00:00
安装数据库时没有设置为大小写区分,写SQL语句要用到大小写区分,故用了以下方式,如有其它方法,请大家指点

区分大小写:select * from table where col='semye' collate Chinese_PRC_CS_AI

不区分大小写:select * from table where col='semye' collate Chinese_PRC_CI_AI

为了便于自己的学习和理解,转载了以下文章:
 
理解collate Chinese_PRC_CI_AS NULL
 
 

    我们在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语句区分大小写(转载)

我们在create table时经常会碰到这样的语句,例如:password nvarchar(10)collate chinese_prc_ci_as null,那它到底是什么意思呢?不妨看看下面:...

SQL Server 强大的分区技术(使用语句检测和优化数据库 (MSSQL个人笔记之数据库优化之路 三)

今天要一起学习下大数据处理技术:分区技术 一般在海量数据处理过程中经常会使用到分区技术把表和视图划分为不同的区域,没个区域中包含满足特定条件的数据。   分区的类型   硬分区 增加冗余的...

[MSSQL]用SQL语句求某文章中出现关键词的个数--【叶子】

一、介绍 最近csdn论坛有人问我这样一个问题,说有一篇文章存在数据库中,然后有三个关键词,说是存取文章信息的时候,返回关键词的个数。故有此文。以供大家参考。 二、sql语句 DECLARE ...

走向DBA[MSSQL篇] 从SQL语句的角度 提高数据库的访问性能

原文地址:http://www.cnblogs.com/dubing/archive/2011/12/09/2278090.html   最近公司来一个非常虎的dba  10几年的经验 这里就称之...

Atitit.mysql oracle with as模式临时表模式 CTE 语句的使用,减少子查询的结构性 mssql sql server..

Atitit.mysql  oracle with as模式临时表模式 CTE 语句的使用,减少子查询的结构性 mssql sql server..   1. with ... as (...) ...
  • attilax
  • attilax
  • 2014年12月10日 23:39
  • 2128

MSSQL Server 数据库备份还原常用SQL语句及注意

关于sql备份恢复的注意事项!

MSSQL Server中通过查看SQL语句执行所用的时间

在MSSQL Server中通过查看SQL语句执行所用的时间,来衡量SQL语句的性能。 set   statistics   profile   on set   statistics  ...

测试mssql中sql语句的执行时间

在MSSQL Server中通过查看SQL语句执行所用的时间,来衡量SQL语句的性能。 set   statistics   profile   on set   statistics   io ...

mssql中SQL语句优化常用方法小结

近几天面试管常问起我sqlserver数据化都用了那些方法时,老是反应迟钝,只回答了看索引和IO,结果让自己都备感伤心啊。现在将自己知道的人优化写下来,只有目录,详细的可以在网上找到很多详细的方案哦。...

手工MSSQL注入常用SQL语句

and exists (select * from sysobjects) //判断是否是MSSQLand exists(select * from tableName) //判断某表是否存在..ta...
  • god_7z1
  • god_7z1
  • 2011年07月08日 01:53
  • 278
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:MSSQL SQL语句区分大小写问题
举报原因:
原因补充:

(最多只允许输入30个字)