需求描述:

  今天遇到了修改lower_case_table_names参数的问题,想了下,如果原来里面有表,表名有大小写的,

  如果将lower_case_table_names从默认的0改为1之后,那么对于原来的表有没有影响.做个实验,在此

  记录下.

操作过程:

1.原来未修改之前,库中创建大小写区分的表

mysql> drop database test05;
Query OK, 2 rows affected (0.05 sec) mysql> create database test05;
Query OK, 1 row affected (0.00 sec) mysql> use test05;
Database changed
mysql> create table tab01(id int); #创建小写的表名
Query OK, 0 rows affected (0.05 sec) mysql> create table Tab01(id int); #创建大写的表名
Query OK, 0 rows affected (0.04 sec) mysql> insert into tab01 select 1; #分别向两个表中插入数据
Query OK, 1 row affected (0.01 sec)
Records: 1 Duplicates: 0 Warnings: 0 mysql> insert into tab01 select 2;
Query OK, 1 row affected (0.00 sec)
Records: 1 Duplicates: 0 Warnings: 0 mysql> insert into tab01 select 3;
Query OK, 1 row affected (0.01 sec)
Records: 1 Duplicates: 0 Warnings: 0 mysql> insert into tab01 select 4;
Query OK, 1 row affected (0.00 sec)
Records: 1 Duplicates: 0 Warnings: 0 mysql> insert into Tab01 select 4;
Query OK, 1 row affected (0.01 sec)
Records: 1 Duplicates: 0 Warnings: 0 mysql> insert into Tab01 select 5;
Query OK, 1 row affected (0.00 sec)
Records: 1 Duplicates: 0 Warnings: 0 mysql> insert into Tab01 select 6;
Query OK, 1 row affected (0.00 sec)
Records: 1 Duplicates: 0 Warnings: 0 mysql> select * from tab01; #小写表名中的数据
+------+
| id |
+------+
| 1 |
| 2 |
| 3 |
| 4 |
+------+
4 rows in set (0.00 sec) mysql> select * from Tab01; #大写表名中的数据
+------+
| id |
+------+
| 4 |
| 5 |
| 6 |
+------+
3 rows in set (0.00 sec)

2.将lower_case_table_name参数修改为1,重启实例

mysql> select * from Tab01; #查询大写表名,发现是小写表的数据
ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...
Connection id: 2
Current database: test05 +------+
| id |
+------+
| 1 |
| 2 |
| 3 |
| 4 |
+------+
4 rows in set (0.01 sec) mysql> select * from tab01; #查询小写表名,还是小写表的数据
+------+
| id |
+------+
| 1 |
| 2 |
| 3 |
| 4 |
+------+
4 rows in set (0.00 sec) mysql> system ls -l /mysql/data/test05 #操作系统上大小写文件都是存在的.
total 220
-rw-r----- 1 mysql mysql 61 Jun 5 17:03 db.opt
-rw-r----- 1 mysql mysql 8556 Jun 5 17:03 tab01.frm
-rw-r----- 1 mysql mysql 8556 Jun 5 17:04 Tab01.frm
-rw-r----- 1 mysql mysql 98304 Jun 5 17:04 tab01.ibd
-rw-r----- 1 mysql mysql 98304 Jun 5 17:05 Tab01.ibd
mysql> insert into Tab01 select * from tab01; #继续向大写表名中插数据.
Query OK, 4 rows affected (0.05 sec)
Records: 4 Duplicates: 0 Warnings: 0 mysql> system ls -l /mysql/data/test05
total 220
-rw-r----- 1 mysql mysql 61 Jun 5 17:03 db.opt
-rw-r----- 1 mysql mysql 8556 Jun 5 17:03 tab01.frm
-rw-r----- 1 mysql mysql 8556 Jun 5 17:04 Tab01.frm
-rw-r----- 1 mysql mysql 98304 Jun 5 17:07 tab01.ibd
-rw-r----- 1 mysql mysql 98304 Jun 5 17:05 Tab01.ibd
mysql> insert into Tab01 select * from tab01;
Query OK, 8 rows affected (0.01 sec)
Records: 8 Duplicates: 0 Warnings: 0 mysql> system ls -l /mysql/data/test05
total 220
-rw-r----- 1 mysql mysql 61 Jun 5 17:03 db.opt
-rw-r----- 1 mysql mysql 8556 Jun 5 17:03 tab01.frm
-rw-r----- 1 mysql mysql 8556 Jun 5 17:04 Tab01.frm
-rw-r----- 1 mysql mysql 98304 Jun 5 17:07 tab01.ibd
-rw-r----- 1 mysql mysql 98304 Jun 5 17:05 Tab01.ibd
mysql> insert into Tab01 select * from tab01;
Query OK, 16 rows affected (0.00 sec)
Records: 16 Duplicates: 0 Warnings: 0 mysql> system ls -l /mysql/data/test05
total 220
-rw-r----- 1 mysql mysql 61 Jun 5 17:03 db.opt
-rw-r----- 1 mysql mysql 8556 Jun 5 17:03 tab01.frm
-rw-r----- 1 mysql mysql 8556 Jun 5 17:04 Tab01.frm
-rw-r----- 1 mysql mysql 98304 Jun 5 17:07 tab01.ibd
-rw-r----- 1 mysql mysql 98304 Jun 5 17:05 Tab01.ibd
mysql> insert into Tab01 select * from tab01;
Query OK, 32 rows affected (0.01 sec)
Records: 32 Duplicates: 0 Warnings: 0 mysql> insert into Tab01 select * from tab01;
Query OK, 64 rows affected (0.01 sec)
Records: 64 Duplicates: 0 Warnings: 0 mysql> insert into Tab01 select * from tab01;
Query OK, 128 rows affected (0.02 sec)
Records: 128 Duplicates: 0 Warnings: 0 mysql> insert into Tab01 select * from tab01;
Query OK, 256 rows affected (0.00 sec)
Records: 256 Duplicates: 0 Warnings: 0 mysql> insert into Tab01 select * from tab01;
Query OK, 512 rows affected (0.02 sec)
Records: 512 Duplicates: 0 Warnings: 0 mysql> insert into Tab01 select * from tab01;
Query OK, 1024 rows affected (0.03 sec)
Records: 1024 Duplicates: 0 Warnings: 0 mysql> system ls -l /mysql/data/test05
total 288
-rw-r----- 1 mysql mysql 61 Jun 5 17:03 db.opt
-rw-r----- 1 mysql mysql 8556 Jun 5 17:03 tab01.frm
-rw-r----- 1 mysql mysql 8556 Jun 5 17:04 Tab01.frm
-rw-r----- 1 mysql mysql 163840 Jun 5 17:08 tab01.ibd #插入多次发现,只有小写表名的文件大小在变化.
-rw-r----- 1 mysql mysql 98304 Jun 5 17:05 Tab01.ibd
mysql> system ls -l /mysql/data/test05
total 288
-rw-r----- 1 mysql mysql 61 Jun 5 17:03 db.opt
-rw-r----- 1 mysql mysql 8556 Jun 5 17:03 tab01.frm
-rw-r----- 1 mysql mysql 8556 Jun 5 17:04 Tab01.frm
-rw-r----- 1 mysql mysql 163840 Jun 5 17:08 tab01.ibd
-rw-r----- 1 mysql mysql 98304 Jun 5 17:05 Tab01.ibd

备注:发现将lower_case_table_names参数从默认的0改为1之后,对于原来表的使用是有影响的,查询的也只是查询小写的表,插入也只是插入到小写的表中,虽然通过show tables能够看到大小写的表同时存在.

文档创建时间:2018年6月5日17:20:23

mysql中已经存在某个库中有大小写的表,将lower_case_table_names由0改为1对已经存在的表是否有影响?的更多相关文章

  1. java中源代码和lib库中有包名和类名都相同的类(转)

    https://blog.csdn.net/itachiwwwg/article/details/9003261 当java的源代码中出现了和系统的lib库中的包名与类名完全一样的类时,系统应当怎么加 ...

  2. MYSQL中关于日期处理的函数

    < DOCTYPE HTML PUBLIC -WCDTD HTML TransitionalEN> MySQL数据库中SQL语句中 关于日期.时间\时间戳的函数   一 MySQL 获得当 ...

  3. mysql中bigint、int、mediumint、smallint 和 tinyint的取值范围

    mysql数据库设计,其中,对于数据性能优化,字段类型考虑很重要,搜集了些资料,整理分享出来,这篇为有关mysql整型bigint.int.mediumint.smallint 和 tinyint的语 ...

  4. mysql 中时间和日期函数应用

    一.MySQL 获得当前日期时间 函数 1.1 获得当前日期+时间(date + time)函数:now() mysql> select now(); +-------------------- ...

  5. mysql中的sql

    变量 用户变量: 在用户变量前加@ 系统变量: 在系统变量前加@@ 运算符 算术运算符有: +(加), -(减), * (乘), / (除) 和% (求模) 五中运算 位运算符有: & (位于 ...

  6. MySQL中MyISAM和InnoDB两种主流存储引擎的特点

    一.数据库引擎(Engines)的概念 MySQ5.6L的架构图: MySQL的存储引擎全称为(Pluggable Storage Engines)插件式存储引擎.MySQL的所有逻辑概念,包括SQL ...

  7. mysql 中 时间和日期函数

    From: http://www.cnblogs.com/redfox241/archive/2009/07/23/1529092.html 一.MySQL 获得当前日期时间 函数 1.1 获得当前日 ...

  8. mysql中时间日期函数

    转自:mysql 中 时间和日期函数 一.MySQL 获得当前日期时间 函数 1.1 获得当前日期+时间(date + time)函数:now() mysql> select now(); +- ...

  9. 【Mysql】mysql中bigint、int、mediumint、smallint 和 tinyint的取值范围

    1.bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字),无符号的范围是0到 1844674 ...

随机推荐

  1. (转) Hadoop1.2.1安装

    环境:ubuntu13 使用的用户为普通用户.如:用户ru jdk安装略 1.安装ssh (1) sudo apt-get install openssh-server (2)配置ssh面密码登录 $ ...

  2. C++生成全局唯一Guid

    在软件开发中,我们经常需要一个唯一标识来标识一个对象,在PHP中,可以用UUID来获得全局唯一的ID,其实C++也内置了简单的GUID获得办法,猜想GUID应该是本机的特征以及运行的时间的一个哈希值, ...

  3. JDK观察者模式和事件机制比较<转>

    原文:(六)观察者模式详解(包含观察者模式JDK的漏洞以及事件驱动模型) 作者:zuoxiaolong8810(左潇龙),转载请注明出处. 本章我们讨论一个除前面的单例以及代理模式之外,一个WEB项目 ...

  4. Java编程的逻辑 (60) - 随机读写文件及其应用 - 实现一个简单的KV数据库

    本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...

  5. 根据城市表生成json数据

    T_CityManager am = new T_CityManager(); string tou = "var LAreaData=["; string value = &qu ...

  6. 【驱动】——错误: 初始值设定项里有未知的字段‘ioctl’

    这个错误网上搜索发现3.0.0.15版本内核 file_operation结构体已经删除了ioctl函数,取代的是: long (*unlocked_ioctl) (struct file *, un ...

  7. mongoDB 删除集合后,空间不释放

    mongoDB 删除集合后,空间不释放,添加新集合,没有重新利用之前删除集合所空出来的空间,也就是数据库大小只增不减. 方法有: 1.导出导入 dump & restore 2.修复数据库 r ...

  8. spring中 context:property-placeholder 导入多个独立的 .properties配置文件

    spring中 context:property-placeholder 导入多个独立的 .properties配置文件? Spring容器采用反射扫描的发现机制,在探测到Spring容器中有一个 o ...

  9. APICloud 真机连接失败

    今天在公司将APICloud 的项目进行趁机测试的时候,发现连接失败,报如下错: 排查步骤: 1.看手机wifi与电脑是否在同一网段: 就是看ip前面的三段是不是一样.比如ip地址是 192.168. ...

  10. svn出现skips remain conficted,不能更新代码问题

    出现: skips remain conficted One or more files are in a conflicted state 然后commit的时候出现,很多都已经deleted,但是 ...