mysql lower case_MySQL参数之lower_case_table_names

lower_case_table_names 参数MySQL 库表 大小写,默认为0

0 库表敏感,区分大小写,指定的大小写保存文件

1 库表不敏感,不区分大小写,文件系统以小写保存

2 使用Create语句指定的大小写保存文件,但MySQL会将之转化为小写,启动的时候日志报警告

a488b7d5615e38ee8f4b1e3668464e6d.png

参数从0调为1

lower_case_table_names =0下操作库表都敏感

mysql> create database wx;

Query OK, 1 row affected (0.01 sec)

mysql> create database WX;

Query OK, 1 row affected (0.00 sec)

mysql> use wx;

Database changed

mysql> show tables;

Empty set (0.00 sec)

mysql> create table wx(id int);

Query OK, 0 rows affected (0.01 sec)

mysql> create table WX(id int);

Query OK, 0 rows affected (0.01 sec)

调整参数lower_case_table_names =1

此时:两表都有表信息,现在虽然有两库,但是在一库中建立表,另一库中也会出现表

mysql> use wx;

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A

Database changed

mysql> show tables;

+--------------+

| Tables_in_wx |

+--------------+

| WX |

| wx |

+--------------+

2 rows in set (0.00 sec)

mysql> use WX;

Reading table information for completion of table and column names

You can turn off this feature to get a quicker startup with -A

Database changed

mysql> show tables;

+--------------+

| Tables_in_wx |

+--------------+

| WX |

| wx |

+--------------+

2 rows in set (0.00 sec)

参数lower_case_table_names =1下操作

mysql> create database ww;

Query OK, 1 row affected (0.01 sec)

mysql> create database WW;

ERROR 1007 (HY000): Can't create database 'ww'; database exists

mysql> use ww;

Database changed

mysql> create table ww(id int);

Query OK, 0 rows affected (0.01 sec)

mysql> create table WW(id int);

ERROR 1050 (42S01): Table 'ww' already exists

参数从0调到1,变化数据文件仅仅存放在小写的库中

[root@wxtest WX]# ls

db.opt

[root@wxtest wx]# ls

db.opt t1.frm t1.ibd wx.frm WX.frm wx.ibd WX.ibd

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Ubuntu上设置MySQLlower_case_table_names参数无效可能是由于以下几个原因: 1. 参数设置错误:请确保在MySQL配置文件中正确设置了lower_case_table_names参数。可以通过编辑/etc/mysql/mysql.conf.d/mysqld.cnf文件来修改参数值。确保在[mysqld]部分添加或修改lower_case_table_names = 1,并重新启动MySQL服务。 2. 配置文件位置错误:在某些情况下,MySQL的配置文件可能位于不同的位置。可以通过运行以下命令来查找配置文件的位置:sudo find / -name "my.cnf"。然后在找到的配置文件中进行相应的修改。 3. 参数冲突:如果在MySQL配置文件中同时设置了lower_case_table_names参数和其他与大小写相关的参数(如lower_case_file_system),可能会导致参数无效。请确保只设置lower_case_table_names参数,并将其他相关参数注释掉或删除。 4. 参数生效范围:lower_case_table_names参数只对新创建的表有效,对于已存在的表可能不会生效。如果需要将已存在的表名转换为小写,可以使用RENAME TABLE语句进行修改。 5. 数据库引擎限制:某些数据库引擎(如InnoDB)可能对lower_case_table_names参数有限制。请确保使用的数据库引擎支持该参数,并且已正确配置。 如果以上方法都无效,您可以尝试重新安装MySQL,并在安装过程中正确设置lower_case_table_names参数。另外,您还可以查看MySQL的错误日志文件(通常位于/var/log/mysql/error.log),以获取更多关于参数设置无效的详细信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值