mysql中数据库名字分大小写吗?

mysql中数据库名字分大小写吗?,第1张

分大小写。

MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:数据库名与表名是严格区分大小写的;表的别名是严格区分大小写的;列名与列的别名在所有的情况下均是忽略大小写的;变量名也是严格区分大小写的;MySQL在Windows下都不区分大小写。

不区分大小写在MySQL中,数据库和表对就于那些目录下的目录和文件。因而, *** 作系统的敏感性决定数据库和表命名的大小写敏感。这就意味着数据库和表名在Windows中是大小写不敏感的,而在大多数类型的Unix系统中是大小写敏感的。

应用环境

与其他的大型数据库例如 Oracle、DB2、SQL Server等相比,MySQL自有它的不足之处,但是这丝毫也没有减少它受欢迎的程度。对于一般的个人使用者和中小型企业来说,MySQL提供的功能已经绰绰有余,而且由于 MySQL是开放源码软件,因此可以大大降低总体拥有成本。

索引是一种特殊的文件(InnoDB 数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针。索引不是万能的,索引可以加快数据检索 *** 作,但会使数据修改 *** 作变慢。

以上内容参考:百度百科-mySQL

第一种:

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

大多数情况下,数据库对象名是不区分大小写的。

什么数据库的表名是大小写区分的?

我所知道的特例是Oracle,正常情况下,无论你输入的表名是大写、还是小写,那么都以大写存储的;使用的时候,大小写都可以。

而用双引号引起来的表名,如果是小写的话,那么使用的时候,必须用双引号引起来的小写才行。


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

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

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

发表评论

登录后才能评论

评论列表(0条)

    保存