MySQL By default is to differentiate the table name from the case of Linux. MySQL case sensitivity setting is determined by the parameter lower_case_table_names, where:
1) lower_case_table_names = 0
Case-sensitive (that is, case insensitive), this setting is the default. When this is set, the table names created in MySQL do not have any effect on uppercase letters, and can be read and referenced normally.
2) Lower_case_table_names = 1
Case-insensitive (that is, case sensitive). When this is set, the table name is saved in lowercase on the hard disk, and MySQL converts all table names to lowercase storage and lookup tables. This behavior is also appropriate for database names and table aliases .
That is, after MySQL is set to non-partition case, when you create a library or a table, you create it with uppercase letters, and when you create it, you are forced to save it in lowercase!
MySQL under Linux database name, table name, column name, alias casing rules are like this:
1) database name and table name are strictly case-sensitive;
2) The alias of the table is strictly case-sensitive;
3) The alias of the column name and column is ignored in all cases;
4) Variable names are also strictly case-sensitive;
5) MySQL is not case-sensitive under Windows, but the default is case-sensitive under Linux.
6) If you want to distinguish the case of a field value at query time, the field value needs to be set to the binary property, which can be set in several ways:
A) settings at creation time:
CREATE TABLE T (A VARCHAR (Ten) BINARY);
b) Modify with alter
So in different operating systems in order to make the program and the database can be normal operation, the best way is to design the table in the time of the lower case!!
Modify MySQL for case-insensitive settings:
Mysqladmin-uroot-p shutdown//Shut down the database in Safe mode
Modify MY.CNF//Add the following line settings
.....
[Mysqld]
Lower_case_table_names=1
.....
Start MySQL
MySQL table name ignores case configuration