mysql lower_case_table_names ---- 一律把表名处理为小写
一、从操作系统说起:
1.我们知道mysql 是跨平台的、它可以在许多平台上运行如windows 、linux、unix(mac)。linux 是类unix的,
但是windows和linux就有非常大的不同了。 windows:文件名不区分大小写、linux:文件名区分大小写;这样会有一个问题
a.txt 和 A.txt 在linux 认为这个是两个不同的文件;windows中认为这个两个同名文件(也就是说你没有法办在同一个文件夹下
不能同时存在a.txt 和 A.txt)
2、为了加深映像我们在一个已经有A.txt 的文件夹下增加一个a.txt 看一下windows会说什么

3、linux下是区分大小写的
[jianglexing@workstudio Desktop]$ cd tmp
[jianglexing@workstudio tmp]$ ll
total
[jianglexing@workstudio tmp]$ touch a.txt
[jianglexing@workstudio tmp]$ touch A.txt
[jianglexing@workstudio tmp]$ ll
total
-rw-rw-r-- jianglexing jianglexing May : a.txt
-rw-rw-r-- jianglexing jianglexing May : A.txt # linux 中a.txt 和B.txt是算不同的文件的 .
二、mysql 是怎样保存数据的:
1、一个数据库对应着文件系统中的一个目录(文件夹)
create database appdb character set utf8;
Query OK, 1 row affected (0.00 sec) mysql> system ls -l /usr/local/mysql/data
total 195964
drwxr-x--- 2 mysql mysql 20 May 28 09:15 appdb #appdb 是个文件夹
-rw-r----- 1 mysql mysql 56 Apr 22 21:29 auto.cnf
-rw------- 1 mysql mysql 1676 Apr 22 21:29 ca-key.pem
-rw-r--r-- 1 mysql mysql 1075 Apr 22 21:29 ca.pem
-rw-r--r-- 1 mysql mysql 1079 Apr 22 21:29 client-cert.pem
-rw------- 1 mysql mysql 1676 Apr 22 21:29 client-key.pem
-rw-r----- 1 mysql mysql 3363466 May 28 09:14 error.log
drwxr-x--- 2 mysql mysql 136 May 22 12:28 fdb
-rw-r----- 1 mysql mysql 654 May 27 23:33 ib_buffer_pool
-rw-r----- 1 mysql mysql 79691776 May 28 09:14 ibdata1
-rw-r----- 1 mysql mysql 50331648 May 28 09:14 ib_logfile0
-rw-r----- 1 mysql mysql 50331648 Apr 22 21:29 ib_logfile1
-rw-r----- 1 mysql mysql 12582912 May 28 09:14 ibtmp1
drwxr-x--- 2 mysql mysql 4096 Apr 22 21:29 mysql
-rw-r----- 1 mysql mysql 685 May 25 16:17 mysql-bin.000027
-rw-r----- 1 mysql mysql 233 May 25 16:17 mysql-bin.000028
-rw-r----- 1 mysql mysql 209 May 25 16:17 mysql-bin.000029
-rw-r----- 1 mysql mysql 233 May 25 16:52 mysql-bin.000030
-rw-r----- 1 mysql mysql 209 May 25 16:52 mysql-bin.000031
-rw-r----- 1 mysql mysql 31389 May 26 17:27 mysql-bin.000032
-rw-r----- 1 mysql mysql 209 May 26 17:27 mysql-bin.000033
-rw-r----- 1 mysql mysql 26331 May 27 13:57 mysql-bin.000034
-rw-r----- 1 mysql mysql 209 May 27 13:57 mysql-bin.000035
-rw-r----- 1 mysql mysql 396 May 27 16:30 mysql-bin.000036
-rw-r----- 1 mysql mysql 209 May 27 16:30 mysql-bin.000037
-rw-r----- 1 mysql mysql 1575 May 27 23:33 mysql-bin.000038
-rw-r----- 1 mysql mysql 209 May 27 23:33 mysql-bin.000039
-rw-r----- 1 mysql mysql 363 May 28 09:15 mysql-bin.000040
-rw-r----- 1 mysql mysql 266 May 28 09:14 mysql-bin.index
drwxr-x--- 2 mysql mysql 8192 Apr 22 21:29 performance_schema
-rw------- 1 mysql mysql 1676 Apr 22 21:29 private_key.pem
-rw-r--r-- 1 mysql mysql 452 Apr 22 21:29 public_key.pem
-rw-r--r-- 1 mysql mysql 1079 Apr 22 21:29 server-cert.pem
-rw------- 1 mysql mysql 1676 Apr 22 21:29 server-key.pem
drwxr-x--- 2 mysql mysql 8192 Apr 22 21:29 sys
drwxr-x--- 2 mysql mysql 4096 May 27 21:27 tempdb
drwxr-x--- 2 mysql mysql 56 May 26 12:48 testdb
-rw-r----- 1 mysql mysql 5 May 28 09:14 workstudio.pid
2 表对应着文件系统中的文件
use appdb;
Database changed
mysql> create table person(id int not null auto_increment primary key,name varchar(8));
Query OK, 0 rows affected (0.00 sec) mysql> create table PERSON(id int not null auto_increment primary key,name varchar(8));
Query OK, 0 rows affected (0.01 sec) mysql> system ls -l /usr/local/mysql/data/appdb/
total 220
-rw-r----- 1 mysql mysql 61 May 28 09:15 db.opt
-rw-r----- 1 mysql mysql 8586 May 28 09:25 person.frm
-rw-r----- 1 mysql mysql 8586 May 28 09:26 PERSON.frm
-rw-r----- 1 mysql mysql 98304 May 28 09:25 person.ibd
-rw-r----- 1 mysql mysql 98304 May 28 09:26 PERSON.ibd # 看到了吧、这样的话linux和windows 就两个平台就不能兼容了;
# 因为windows 认为PERSON.ibd == person.ibd
# person.frm == PERSON.frm
三、lower_case_table_names 兼容windows & linux :
1 如果把lower_case_table_names 设置为1 、那么mysql会把SQL语句中所有的表名都变成小写;
2 lower_case_table_names 应该在初始化MySQL的时候就完成的、不然可能会引起一引起问题;
如:
lower_case_table_names 主要是为了兼容windows & linux
----
学习交流

mysql lower_case_table_names ---- 一律把表名处理为小写的更多相关文章
- mysql解决select * from 表名 (where + 约束条件为空)
mysql解决select * from 表名 (where + 约束条件为空),示例如下: SELECT * from tableName WHERE name is NULL; 从 tableNa ...
- 让 MySQL 在 Linux 下表名不区分大小写(实为表名全小写)
把 Windows 下的应用部署到 Linux 下,使用到了 Quartz 集群的特性,所以建了 MySql 的中间表,一启动看到报错: Invocation of init method faile ...
- 更改MYSQL数据库不区分大小写表名
今天郁闷死了,在LINUX下调一个程序老说找不到表,但是我明明是建了表的,在MYSQL的命令行下也可以查到,为什么程序就找不到表呢? 后来请教了一个老师才搞定,原来是LINUX下的MYSQL默认是要区 ...
- linux环境下mysql默认是区分表名大小写的
在linux环境下,mysql默认表明是区分大小写的,我们可以查看全局变量发现: mysql> show variables like 'lower%'; +------------------ ...
- mysql数据库如何设置表名大小写不敏感?
转自:https://blog.csdn.net/iefreer/article/details/8313839 在跨平台的程序设计中要注意到mysql的一些系统变量在windows和linux上的缺 ...
- mysql 远程登录与表名大小写问题
好久没写博客了,这段时间在学习一个开源的项目,里面使用到了mysql,好久没使用mysql了.在使用过程中遇到了一个问题,远程登陆.报错信息很明显,连接失败.解决思路如下: 1. 首先检查到服务器网络 ...
- MySQL中 optimize table '表名'的作用
语法: optimize table '表名' 一,原始数据 1,数据量 2,存放在硬盘中的表文件大小 3,查看一下索引信息 索引信息中的列的信息说明. Table :表的名称.Non_unique: ...
- 关于mysql存储过程创建动态表名及參数处理
转载请注明出处:帘卷西风的专栏(http://blog.csdn.net/ljxfblog) 近期游戏開始第二次内測,開始处理操作日志.最開始把日志放到同一个表里面,发现一天时间,平均100玩家 ...
- MYSQL中只知表名查询属于哪个SCHEMA
只知道表名XXX查该表属于哪个schema.以及该表有哪些列等信息 SELECT * from information_schema.columns WHERE table_name = 'xxx'; ...
随机推荐
- Mac OS上的远程桌面
最近在做Mac上面的开发,经常在win7和Mac两台电脑上操作,两个键盘,两个鼠标,搞得头都大了,所以干脆把Mac机器远程到win7上面,统一来做,方便些..哈哈!说实话,Mac键盘那些按键真还有点特 ...
- 获取easyui calendar 属性
<div id="cc" class="easyui-calendar" style="width:250px;height:250px;&qu ...
- C#的四个基本技巧
1.如果可能尽量使用接口来编程 .NET框架包括类和接口,在编写程序的时候,你可能知道正在用.NET的哪个类.然而,在这种情况下如果你用.NET支持的接口而不是它的类来编程时,代码会变得更加稳定.可用 ...
- 使用mocha测试
学习了MOCHA官网的示例,将学习成果记录一下.[原文+例子:使用mocha测试] mocha是什么 Mocha是一个跑在node和浏览器上的javascript测试框架,让异步测试变得简单有趣, 并 ...
- 免费的多数据库管理工具sqldbx个人版本
SqlDbx是一个先进的Sql编辑器和数据库对象资源管理器SqlDbx仅一个可执行的文件不需要安装 SqlDbx与SSMS对象内存占差的不是一点点,但功能与SSMS相当 优点:支持多数据库,占用内存小 ...
- Hidden Markov Model Toolbox for Matlab
官网:http://www.cs.ubc.ca/~murphyk/Software/HMM/hmm.html Download Click here. Unziping creates a direc ...
- [React + Functional Programming ADT] Create Redux Middleware to Dispatch Actions with the Async ADT
We would like the ability to group a series of actions to be dispatched with single dispatching func ...
- eclipse解决editor does not contain a main type的方法
转自:http://blog.csdn.net/huazhangena/article/details/7349044 写在前面的话:我的也出现这个问题,但是解决方法和转发的内容不太一样,原理一样,我 ...
- 通过Intel XDK编写跨平台app(一)
Intel XDK 是一个新的跨平台手机应用开发工具.它努力把整个开发流程变的简单,尽可能把所有的平台都封装到一个包中,通过收集各种开发工具来使你的开发变的简单. 在这篇文章中,我将会向你介绍什么是I ...
- Android provider中使用sqlite内存数据库
sqlite是支持内存数据库的,在Android中,我们可以通过provider实现内存数据库操作.内存数据库的优点,访问速度快,但在连接关闭后,数据库自动消失(在android中的表现是,provi ...