有时候查询数据库的时候会发现(比如做重名检查的时候):数据库的查询时对大小写不敏感的,也就是 A 和 a 是一样的。

也就是说 select * from tabletest where name = 'a' 和 select * from tabletest where name = 'A'

两条 sql 语句的执行结果是一样的。

该怎么办呢。。。百度了一下,才了解到这关系到了 SQL SERVER 的排序规则。之前在安装 SQL SERVER 的时候曾经见到过这个选项,但是一直没明白是啥意思。。。

可能这个排序规则的翻译也比较迷惑,英文原文是  collation ,查了一下词典,好像意思是校对整理什么的,反正没看见直接有排序的意思。

不过这个东西也确实跟排序有关,比如有一系列的姓名(中文)数据,就可以指定按拼音排序(Chinese_PRC_)呀,还是按笔画排序(Chinese_PRC_Stroke_)什么的。。。

更多排序规则可查看:https://technet.microsoft.com/zh-cn/library/ms188046.aspx

这里是要为了解决大小写敏感的问题,好吧,也在上面那个网页中有解释,可以设置以下参数:

 

CaseSensitivity
    CI 指定不区分大小写,CS 指定区分大小写。
AccentSensitivity
    AI 指定不区分重音,AS 指定区分重音。
KanatypeSensitive
    Omitted 指定不区分假名类型,KS 指定区分假名类型。
WidthSensitivity
    Omitted 指定不区分全半角,WS 指定区分全半角。

 

设置排序规则的 sql 语句为:

COLLATE Chinese_PRC_CS_AS_KS_WS

前半部分是排序相关的,后半部分就是上面列的那四个选项了,可以根据需要随意添加修改。。。具体怎么加。。。

--要不就百度一下,或者看上面的MSDN链接里面的例子,不想写了。。。

MSDN:https://technet.microsoft.com/zh-cn/library/ff848763.aspx

排序规则可以对服务器进行设置,也可以对数据库进行设置,可以对数据表中的列进行设置,或者随用随设也可以

除了使用 sql 语句设置,还可以通过 SSMS 图形界面设置:

服务器设置可能比较麻烦,需要先停止服务器什么的,最好在安装的时候设置好吧

数据库就直接属性选项里面有下拉列表可以选择设置。

对数据表中的列,在表设计器下面的列属性上可以设置

嗯,还有图形界面可以选择选项(●'◡'●)

请原谅我写的简单。。。(完)

SQL SERVER 的排序规则的更多相关文章

  1. SQL Server更改排序规则的实现过程

    摘自: http://www.2cto.com/database/201112/115138.html 以下的文章主要向大家描述的是SQL Server更改排序规则的实现过程,以及在实现其实际操作过程 ...

  2. SQL SERVER修改排序规则——脚本篇

    在上篇MS SQL 排序规则总结中,大致就数据库服务器排序规则(或者叫数据库实例排序规则).数据库排序规则.列的排序规则粗浅的叙说了一遍,重点讲述了修改数据库服务器排序规则(数据库实例排序规则),其中 ...

  3. 修改SQL Server 的排序规则(转)

    转自http://jimshu.blog.51cto.com/3171847/1095780/ 一.修改SQL Server服务器(实例)的排序规则 以下实验使用了SQL Server 2008 R2 ...

  4. [转]SQL SERVER 的排序规则

    如何更改SQL SERVER 2000的排序规则 -- 增加复合主键语句 Alter Table tableName Add primary key (field1,field2) Alter dat ...

  5. 全库修改SQL Server现有排序规则

    近日,在项目Debug过程中发现了SQL Server排序规则冲突的问题. 由于原数据库是从英文环境的SQL中生成的,其排序规则为“SQL_Latin1_General_CP1_CI_AS”,备份到本 ...

  6. SQL SERVER 强制排序规则查询

    有时会需要在2个DB之间的数据做比较, 但因为一些原因, 数据库的默认排序规则是不一样的, 例如 SELECT A.Col1, B.Col1, A.* FROM DB1.dbo.A LEFT JOIN ...

  7. sql server不同排序规则的数据库间字段的比较

    不同的排序规则的字段是不能直接比较的.会提示:无法解决 equal to 操作的排序规则冲突.可以把字段强制转换一个排序规则,这样就能比较了.示例: ------------------------- ...

  8. SQL Server 修改排序规则

    Net stop mssqlserver Setup /QUIET /ACTION=REBUILDDATABASE /instancename=mssqlserver /SQLSYSADMINACCO ...

  9. sql server自定义排序

    方法一: 比如需要对SQL表中的字段NAME进行如下的排序:张三(Z)李四(L)王五(W)赵六(Z) 按照sql中的默认排序规则,根据字母顺序(a~z)排,结果为:李四  王五 赵六 张三 自定义排序 ...

随机推荐

  1. go语言生成uuid

    操作系统: CentOS 6.9_x64 go语言版本: 1.8.3 问题描述 golang没有提供生成uuid的接口,但开发中确实需要uuid. 这里把看到的代码记录下,也方便我以后查阅. 解决方案 ...

  2. MVC+WCF框架下广告位管理——文件上传

    广告位是站点中不可缺少的内容之中的一个.也是能直接给我们站点带来经济收益的内容之中的一个. 好的广告位不仅不会强宾压主,而会为我们的站点锦上添花.起到画龙点睛的作用.因此设计好广告位也是开发过程中一大 ...

  3. Oracle 中包(Package)

    一.什么要使用包?        在一个大型项目中,可能有很多模块,而每个模块又有自己的过程.函数等.而这些过程.函数默认是放在一起的(如在PL/SQL中,过程默认都是放在一起 的,即Procedur ...

  4. maven-war-plugin 插件 web.xml 缺失时忽略

    我们很多时候开发Spring MVC 项目时我们完全可以使用Java Bean 和 Annotation 的方式来配置 Spring MVC 的 DispatcherServlet,而不再采用传统的 ...

  5. oracle 批量删除表数据的4种方式

      1.情景展示 情景一: 删除PRIMARY_INDEX_TEST表中,MINDEX_ID字段为空的数据 情景二: 删除VIRTUAL_CARD_TEST表中的脏数据 2.解决方案 情景一的解决方案 ...

  6. Xcode SVN配置

    Xcode SVN配置 编辑 ~/.subversion/config 文件  注意:假设".subversion"文件夹不存在.请执行"svn status" ...

  7. 防止跨站请求伪造(CSRF)攻击 和 防重复提交 的方法的实现

    CSRF的概念可以参考:http://netsecurity.51cto.com/art/200812/102951.htm 本文介绍的是基于spring拦截器的Spring MVC实现 首先配置拦截 ...

  8. Apk反编译助手

    Android是一个让人很纠结的产品,它开源开放,但是也有很多蛋疼坑爹的地方,还是那句话,谁开发谁知道! Apk反编译助手,懒人和对command line无爱的同学们可下载看看,至少需要.net 2 ...

  9. Maven + SpringMVC项目集成Swagger

    Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件的方法,参数和模型紧密集成到服 ...

  10. oracle中生成大批量数据的方法-下

    方法五:使用PLSQL的数据生成器 首先测试环境建立:dept表 CREATE TABLE dept(deptno NUMBER(6),dname VARCHAR2(20),loc VARCHAR2( ...