MySQL5.7修改大小写敏感后table doesn't exit
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL5.7修改大小写敏感后table doesn't exit,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含5444字,纯文字阅读大概需要8分钟。
内容图文
![MySQL5.7修改大小写敏感后table doesn't exit](/upload/InfoBanner/zyjiaocheng/519/28e17167c6f64cb396820ad6cd026fe9.jpg)
Column, index, stored routine, and event names are not case-sensitive on any platform, nor are column aliases.
However, names of logfile groups are case-sensitive. This differs from standard SQL.
By default, table aliases are case-sensitive on Unix, but not so on Windows or macOS. The following statement would not work on Unix, because it refers to the alias both as a
and as A
:
mysql> SELECT col_name FROM tbl_name AS a
WHERE a.col_name = 1 OR A.col_name = 2;
However, this same statement is permitted on Windows. To avoid problems caused by such differences, it is best to adopt a consistent convention, such as always creating and referring to databases and tables using lowercase names. This convention is recommended for maximum portability and ease of use.
How table and database names are stored on disk and used in MySQL is affected by the lower_case_table_names
system variable, which you can set when starting mysqld. lower_case_table_names
can take the values shown in the following table. This variable does not affect case sensitivity of trigger identifiers. On Unix, the default value of lower_case_table_names
is 0. On Windows, the default value is 1. On macOS, the default value is 2.
Value | Meaning |
---|---|
0 |
Table and database names are stored on disk using the lettercase specified in the CREATE TABLE or CREATE 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 macOS). 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 or CREATE 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 and view names are stored in lowercase, as for lower_case_table_names=1 . |
If you are using MySQL on only one platform, you do not normally have to change the lower_case_table_names
variable from its default value. However, you may encounter difficulties if you want to transfer tables between platforms that differ in file system case sensitivity. For example, on Unix, you can have two different tables named my_table
and MY_TABLE
, but on Windows these two names are considered identical. To avoid data transfer problems arising from lettercase of database or table names, you have two options:
-
Use
lower_case_table_names=1
on all systems. The main disadvantage with this is that when you useSHOW TABLES
orSHOW DATABASES
, you do not see the names in their original lettercase. -
Use
lower_case_table_names=0
on Unix andlower_case_table_names=2
on Windows. This preserves the lettercase of database and table names. The disadvantage of this is that you must ensure that your statements always refer to your database and table names with the correct lettercase on Windows. If you transfer your statements to Unix, where lettercase is significant, they do not work if the lettercase is incorrect.Exception: If you are using
InnoDB
tables and you are trying to avoid these data transfer problems, you should setlower_case_table_names
to 1 on all platforms to force names to be converted to lowercase.
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
:
RENAME TABLE T1 TO t1;
To convert one or more entire databases, dump them before setting lower_case_table_names
, then drop the databases, and reload them after setting lower_case_table_names
:
-
Use mysqldump to dump each database:
mysqldump --databases db1 > db1.sql mysqldump --databases db2 > db2.sql ...
Do this for each database that must be recreated.
-
Use
DROP DATABASE
to drop each database. -
Stop the server, set
lower_case_table_names
, and restart the server. -
Reload the dump file for each database. Because
lower_case_table_names
is set, each database and table name will be converted to lowercase as it is recreated:mysql < db1.sql mysql < db2.sql ...
Object names may be considered duplicates if their uppercase forms are equal according to a binary collation. That is true for names of cursors, conditions, procedures, functions, savepoints, stored routine parameters, stored program local variables, and plugins. It is not true for names of columns, constraints, databases, partitions, statements prepared with PREPARE
, tables, triggers, users, and user-defined variables.
File system case sensitivity can affect searches in string columns of INFORMATION_SCHEMA
tables. For more information, see Section 10.8.7, “Using Collation in INFORMATION_SCHEMA Searches”.
MySQL5.7修改大小写敏感后table doesn't exit
标签:官方文档 html func base reserve 令行 fine scribe rap
本文系统来源:https://www.cnblogs.com/dancaimingzhu/p/12372438.html
内容总结
以上是互联网集市为您收集整理的MySQL5.7修改大小写敏感后table doesn't exit全部内容,希望文章能够帮你解决MySQL5.7修改大小写敏感后table doesn't exit所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。