SQLserver数据库怎么给指定的表区分大小写?

SQLserver数据库怎么给指定的表区分大小写?,第1张

这个 ALTER DATABASE 语句用来修改数据库的属性,比如改变它的默认排序规则(即 COLLATE)。因此,你可以使用它来设置数据库中所有表都区分大小写

要使用这个语句,你需要先确保你有足够的权限去修改数据库。然后,你可以在 SQL Server Management Studio 中执行以下步骤:

打开 SQL Server Management Studio 并连接到你想要修改的数据库服务器。

在对象资源管理器中,右键单击你想要修改的数据库,然后选择“属性”。

在“数据库属性”窗口中,选择“排序规则”选项卡。

在“排序规则”下拉列表中,选择“Chinese_PRC_CS_AS”。

单击“确定”按钮以保存更改。

这样,数据库中的所有表都将区分大小写。但是,如果你只想修改某个特定的表,那么你可以在创建表时指定它的排序规则,或者使用 ALTER TABLE 语句来修改表的排序规则。

举个例子,假设你想要修改名为“TBL_ACCOUNT”的表,使其区分大小写,你可以在创建表时指定排序规则:

这个 ALTER DATABASE 语句用来修改数据库的属性,比如改变它的默认排序规则(即 COLLATE)。因此,你可以使用它来设置数据库中所有表都区分大小写。

要使用这个语句,你需要先确保你有足够的权限去修改数据库。然后,你可以在 SQL Server Management Studio 中执行以下步骤:

打开 SQL Server Management Studio 并连接到你想要修改的数据库服务器。

在对象资源管理器中,右键单击你想要修改的数据库,然后选择“属性”。

在“数据库属性”窗口中,选择“排序规则”选项卡。

在“排序规则”下拉列表中,选择“Chinese_PRC_CS_AS”。

单击“确定”按钮以保存更改。

这样,数据库中的所有表都将区分大小写。但是,如果你只想修改某个特定的表,那么你可以在创建表时指定它的排序规则,或者使用 ALTER TABLE 语句来修改表的排序规则。

举个例子,假设你想要修改名为“TBL_ACCOUNT”的表,使其区分大小写,你可以在创建表时指定排序规则:

CREATE TABLE TBL_ACCOUNT (

id INT PRIMARY KEY,

username VARCHAR(255) COLLATE Chinese_PRC_CS_AS,

password VARCHAR(255)

)

或者,如果你已经创建了表,你可以使用 ALTER TABLE 语句来修改表的排序规则:

ALTER TABLE TBL_ACCOUNT

ALTER COLUMN username VARCHAR(255) COLLATE Chinese_PRC_CS_AS

这样就可以让表“TBL_ACCOUNT”区分大小写了。

第一种:

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  --(指定整个数据库)

第二种:

--创建如下用户自定义函数(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,@i+1,1))=ASCII(SUBSTRING(@Str2,@i+1,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

第三种:

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()一起用


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9919894.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-03
下一篇2023-05-03

发表评论

登录后才能评论

评论列表(0条)

    保存