lowerCaseTableNames

数据库表,数据库名大小写铭感问题

mysql lower-case-table-names参数

线上有业务用到开源的产品,其中SQL语句是大小写混合的,而建表语句都是小写的,mysql默认设置导致这些执行失败。
就需要设置忽略大小写。设置lower-case-table-names=1,重启mysql实例生效。
这时就产生了另外一个问题,之前的大写字母的数据库名都失效了。都提示找不到数据库名。注释掉个lower-case-table-names=1.
则没有这个问题,因此这个问题肯定是lower-case-table-names参数引起的。故查找了官方解释:

Mysql官方文档的介绍:


Value


Meaning


0


Table and database names are stored on disk using the lettercase
specified in the CREATE TABLE orCREATE DATABASE statement.
Name comparisons are case sensitive. You should not set
this variable to 0 if you are running MySQL on a system that has
case-insensitive file names (such as Windows or Mac OS X). If you force this
variable to 0 with --lower-case-table-names=0 on
a case-insensitive file system and access MyISAM tablenames using different lettercases, index corruption
may result.


1


Table names are stored in lowercase on disk and name comparisons
are not case sensitive. MySQL converts all table names to lowercase on
storage and lookup. This behavior also applies to database names and table
aliases.


2


Table and database names are stored on disk using the lettercase
specified in the CREATE TABLE orCREATE DATABASE statement,
but MySQL converts them to lowercase on lookup. Name comparisons are not case
sensitive. This works only on file systems that are not case sensitive! InnoDB table names are
stored in lowercase, as for lower_case_table_names=1.

默认为0,大小写敏感。

设置1,大小写不敏感。创建的表,数据库都是以小写形式存放在磁盘上,对于sql语句都是转换为小写对表和DB进行查找。

设置2,创建的表和DB依据语句上格式存放,凡是查找都是转换为小写进行。

If you plan to set the lower_case_table_names system
variable to 1 on Unix, you must first convert your old database and table names
to lowercase before stopping mysqld and
restarting it with the new variable setting. To do this for an individual
table, use RENAME TABLE:

当想设置lower_case_table_names = 1时,在重启数据库实例之前就需要将原来的数据库和表转换为小写。

官方文档的解释。要开启lower_case_table_names = 1 。先要将大写字母数据库更改为小写。否则将找不到数据库名。

所以要想忽略大小写,还需要提前将大写数据库名更改小写,否则报错。数据库名无法rename.可以新建一个小写的数据库名。
然后rename table 到新的数据库,完成表的迁移。

在进行数据库参数设置之前,需要掌握这个参数带来的影响,切不可盲目设置。

时间: 2024-10-09 04:31:36

lowerCaseTableNames的相关文章

mysql 大小写取消敏感设置

#mysqld --SET-lower_case_table_names=1; 或者在mysql server的配置文件中添加配置项: vi /etc/my.cnf lower_case_table_names=1 该变量值的详细定义如下: Value Meaning 0 Table and database names are stored on disk using the lettercase specified in the CREATE TABLE orCREATE DATABASE 

【已解决】Windows下 MySQL大小写敏感 解决方案及分析

Windows下 MySQL大小写敏感配置 [email protected] http://www.cnblogs.com/swje/ 作者:Zhouwan 2017-3-27 最近在window系统下 操作Linux系统下创建的数据库,发现有些不对劲,比较了半天才发现是大小写敏感的问题造成的.网上搜索了一下,解决了这个问题,做个简明扼要的记录. 按照网上的说明: WINDOWS: 编辑MySQL安装目录下的my.ini 文件,在[mysqld]节下 添加 lower_case_table_n

linux(centOS6) 安装Mysql 5.6.19数据库步骤、 问题以及相应的解决办法

数据库版本:Ver 14.14 Distrib 5.6.19, for Linux (x86_64) using  EditLine wrapper linux版本: Linux version 2.6.32-279.el6.x86_64 ([email protected]) (gcc ve rsion 4.4.6 20120305 (Red Hat 4.4.6-4) (GCC) ) #1 SMP Fri Jun 22 12:19:21 UTC 20 12 采用的rpm安装方式. 1.官网下载

Linux下部署MySQL,大小写敏感踩坑记录

今天在将开发环境中的门户数据库复制到新环境后,使用SqlSugar的ORM框架进行数据库操作的时候,出现了主键找不到的现象.排查了很久终于发现了关键点.特此记录. 1.开发环境:    操作系统:CENTOS7 64位    内存:    1GB    CPU     1/1    网络适配器:网桥模式    安装模式:最小化安装    系统语言设置:zh_CN.gb2312        数据库版本:MySQL 5.6.29 binary 模式安装    建立数据库之前:my.cnf参数配置 

MySQL数据表中内容大小写区分的设置

MYSQL在默认的情况下查询是不区分大小写的,例如: ? 1 2 3 4 5 6 7 mysql> create table t1( -> name varchar(10)); Query OK, 0 rows affected (0.09 sec) mysql> insert into t1 values('you'),('You'),('YOU'); Query OK, 3 rows affected (0.05 sec) Records: 3 Duplicates: 0 Warni

更改MySql表和字段区分大小写

数据库和表名在 Windows 中是大小写不敏感的 ,而在大多数类型的 Unix 系统中是大小写敏感的Windows 版的 MySQL 默认继承 os 的大小写习惯,即使 SQL中有区分,在导入的时候都会被转为小写,如果今后再将此数据库导出就可能存在大小写的问题.my.ini 中有属性lower_case_table_names 可以更改此默认值,要严格区分大小写,将此项的置设置为2,再重启 MySQL 服务即可.参考:[mysqld]lower_case_table_names=2 如果没有,

Mysql 大小写问题

今天发布程序的时候,日志报错找不到表,但是系统中已经存在表,最后发现是sql大小写的问题,mysql默认设置导致这些执行失败. 1.用ROOT登录,修改/etc/my.cnf 2.在[mysqld]下加入一行:lower_case_table_names=1 3.重新启动数据库即可 就需要设置忽略大小写.设置lower-case-table-names=1,重启mysql实例生效. 这时就产生了另外一个问题,之前的大写字母的数据库名都失效了.都提示找不到数据库名.注释掉个lower-case-t

mysql优化之配置文件

[client] port            = 3306 socket          = /tmp/mysql.sock [mysqld] port            = 3306 socket          = /tmp/mysql.sock skip-external-locking log-error=/usr/local/mysql/log/error.log key_buffer_size = 5G max_allowed_packet = 50M table_ope

Mysql大小写敏感

Author:Skate Time:2015/03/11 Mysql大小写敏感 字符串大小写敏感和Mysql的数据库的名字.表名字.字段名字.还有字段值有关. 1.和数据库名字.表名字.存储过程和触发器有关 Mysql中控制数据库名和表名的大小写敏感是由参数lower_case_table_names控制, 为0时: 表示区分大小写,使用CREATE TABLE或CREATE DATABASE语句指定的大小写字母在硬盘上保存表名和数据库名. 名称比较对大小写敏感.在大小写不敏感的操作系统如win