加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQLServer数据库区分大小写的几种方法 (转)

发布时间:2020-12-12 16:04:25 所属栏目:MsSql教程 来源:网络整理
导读:刚刚使用sql server没有几天,发现一个很郁闷的问题,sql server 竟然不区分大小写. 比如: select * from abc_tbl where field_1 = 'abc',这个sql跟这个sql是一样的: select * from abc_tbl where field_1 = 'ABC',上网search了一下,赶紧收藏: 第一种:(蟋蟀) A

刚刚使用sql server没有几天,发现一个很郁闷的问题,sql server 竟然不区分大小写. 比如: select * from abc_tbl where field_1 = 'abc',这个sql跟这个sql是一样的: select * from abc_tbl where field_1 = 'ABC',上网search了一下,赶紧收藏:

第一种:(蟋蟀)
ALTER TABLE tb?? (指定某表的某列)
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CI_AS ? ? ? ? ? --不区分大小写

ALTER TABLE tb?? (指定某表的某列)
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CS_AS ? ? ? ?? --区分大小写

alter database 数据库 COLLATE Chinese_PRC_CS_AS? (指定整个数据库)

第二种:(tree)
--创建如下用户自定义函数(UDF)

CREATE FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
--ALTER FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
RETURNS INTEGER
AS
BEGIN
??DECLARE @i INTEGER
??--DECLARE @Str1 VARCHAR(50)
??--DECLARE @Str2 VARCHAR(50)
??DECLARE @y INT
??--SET @Str1='a'
??--SET @Str2='A'
??SET??@i=0
??--SELECT ASCII(SUBSTRING(@Str1,@i+1,1))
??SET @y=1
??DECLARE @iLen INT
??SET @iLen = LEN(LTRIM(RTRIM(@Str1)))
??IF LEN(LTRIM(RTRIM(@Str1))) < LEN(LTRIM(RTRIM(@Str2))) --THEN
?????SET @iLen = LEN(LTRIM(RTRIM(@Str2)))
??WHILE (@i < @iLen)
????BEGIN
??????IF (ASCII(SUBSTRING(@Str1,1))=ASCII(SUBSTRING(@Str2,1))) --THEN
?????????SET @i = @i +1
??????ELSE
?????????BEGIN
???????????SET @y=0
???????????BREAK
?????????END
??????END
?????RETURN @y
END

测试:
select *
from Table1
Where dbo.StrComp(Field1,'aAbB') =1

第三种:(Oliver)
SQL Server 数据库中的文本信息可以用大写字母、小写字母或二者的组合进行存储。例如,姓氏可以"SMITH"、"Smith"或"smith"等形式出现。

数据库是否区分大小写取决于 SQL Server 的安装方式。如果数据库区分大小写,当搜索文本数据时,必须用正确的大小写字母组合构造搜索条件。例如,如果搜索名字"Smith",则不能使用搜索条件"=smith"或"=SMITH"。

另外,如果服务器被安装成区分大小写,则必须用正确的大小写字母组合提供数据库、所有者、表和列的名称。如果提供的名称大小写不匹配,则 SQL Server 返回错误,报告"无效的对象名"。

当使用关系图窗格和网格窗格创建查询时,查询设计器始终正确地反映出服务器是否区分大小写。但是,如果在 SQL 窗格中输入查询,则必须注意使名称与服务器解释名称的方式相匹配。

如果服务器是用不区分大小写的选项安装的,则
提示?? 若要确定服务器是否区分大小写,请执行存储过程 sp_server_info,然后检查第 18 行的内容。如果服务器是用不区分大小写的设置安装的,则 sort_order 选项将设置为"不区分大小写"。可以从查询分析器运行存储过程。

第四种:(非云)
select * from servers where convert(varbinary,name)=convert(varbinary,N'RoCKEY')

第五种:()

ascii('a')再配合Substring()一起用

?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读