一、从操作系统说起

  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 ---- 一律把表名处理为小写的更多相关文章

  1. mysql解决select * from 表名 (where + 约束条件为空)

    mysql解决select * from 表名 (where + 约束条件为空),示例如下: SELECT * from tableName WHERE name is NULL; 从 tableNa ...

  2. 让 MySQL 在 Linux 下表名不区分大小写(实为表名全小写)

    把 Windows 下的应用部署到 Linux 下,使用到了 Quartz 集群的特性,所以建了 MySql 的中间表,一启动看到报错: Invocation of init method faile ...

  3. 更改MYSQL数据库不区分大小写表名

    今天郁闷死了,在LINUX下调一个程序老说找不到表,但是我明明是建了表的,在MYSQL的命令行下也可以查到,为什么程序就找不到表呢? 后来请教了一个老师才搞定,原来是LINUX下的MYSQL默认是要区 ...

  4. linux环境下mysql默认是区分表名大小写的

    在linux环境下,mysql默认表明是区分大小写的,我们可以查看全局变量发现: mysql> show variables like 'lower%'; +------------------ ...

  5. mysql数据库如何设置表名大小写不敏感?

    转自:https://blog.csdn.net/iefreer/article/details/8313839 在跨平台的程序设计中要注意到mysql的一些系统变量在windows和linux上的缺 ...

  6. mysql 远程登录与表名大小写问题

    好久没写博客了,这段时间在学习一个开源的项目,里面使用到了mysql,好久没使用mysql了.在使用过程中遇到了一个问题,远程登陆.报错信息很明显,连接失败.解决思路如下: 1. 首先检查到服务器网络 ...

  7. MySQL中 optimize table '表名'的作用

    语法: optimize table '表名' 一,原始数据 1,数据量 2,存放在硬盘中的表文件大小 3,查看一下索引信息 索引信息中的列的信息说明. Table :表的名称.Non_unique: ...

  8. 关于mysql存储过程创建动态表名及參数处理

      转载请注明出处:帘卷西风的专栏(http://blog.csdn.net/ljxfblog)  近期游戏開始第二次内測,開始处理操作日志.最開始把日志放到同一个表里面,发现一天时间,平均100玩家 ...

  9. MYSQL中只知表名查询属于哪个SCHEMA

    只知道表名XXX查该表属于哪个schema.以及该表有哪些列等信息 SELECT * from information_schema.columns WHERE table_name = 'xxx'; ...

随机推荐

  1. JavaScript的最大函数參数长度和最大栈深度检測

    一般代码也许不会涉及最大參数长度和最大栈深度,但某些特殊场合,检測这两个參数还是有必要的.比如:用递归计算斐波那契数列的第n个值,不了解最大栈深度,难免显得肤浅.又比如:将一串charCode转成St ...

  2. Html基础知识详解

    一定要做的符合客户要求,不是自己认为对的. 一.基础标签 1.1 大小颜色位置 <!DOCTYPE HTML> <html> <head> <meta htt ...

  3. (转)H264通过RTMP发布 V2.0 (Red5 Wowza 测试通过)

    直接上代码 // demo.cpp : 定义控制台应用程序的入口点.//#include "stdafx.h"#includeextern "C"{#inclu ...

  4. 【资料】wod旗帜,纹章

    物品 徽章 旗帜 掉落地点 备注 火焰纹章 法师与怪物 火焰魔法.魔法攻防 雄鹰纹章 受诅咒的遗迹 弩系相关 盗贼纹章 捉迷藏 偷袭.匕首.割喉.近攻防 守夜人的纹章 酒馆里平静的一天 钝器.双打.旋 ...

  5. Appium+python自动化11-adb必知必会的几个指令

    前言 学android测试,adb是必学的,有几个常用的指令需要熟练掌握 一.检查设备 1.如何检查手机(或模拟器)是连上电脑的,在cmd输入: >adb devices

  6. 关于fmri数据分析的两大类,四种方法

    关于fmri数据分析的两大类,四种方法: 数据驱动: tca:其实这种方法,主要是提取时间维的特征.如果用它来进行数据的分析,则必须要利用其他的数据方法,比如结合ICA. ica:作为pca的一般化实 ...

  7. 解决:解压zip文件却变成cpgz文件

    众所周知,zip是一种压缩文件格式,MAC OS默认支持的文件格式,当时偶尔当你打开zip文件想要解压时,却自动变成了cpgz文件而没有解压,再双击这个cpgz文件,Archive Utility又会 ...

  8. hdu-4725-The Shortest Path in Nya Graph-层次网络

    我们依据每一个人的layer把同样layer的人分配到同一个层次中. 然后记录走到每一个层次的最小值. 假设这个最小值被更新了. 那么我们就更新与这个层次相连的层次上的点. 其它的就是最普通的spfa ...

  9. jQuery中读取json文件

    json文件是一种轻量级的数据交互格式.一般在jquery中使用getJSON()方法读取. $.getJSON(url,[data],[callback]) url:加载的页面地址 data: 可选 ...

  10. linux 处理键盘 鼠标事件

    Linux下鼠标和键盘的模拟控制,也就是为手势和语音控制鼠标和键盘部分服务的. 有关于本系统构建的文章结构都会由三个部分来组织,一是该功能模块的介绍和在Linux下简单应用程序的实现:二是将该功能模块 ...