MySQL大小写敏感疑问分析
发布时间:2021-12-20 14:34:03 所属栏目:MySql教程 来源:互联网
导读:这篇文章主要介绍MySQL大小写敏感问题分析,在日常操作中,相信很多人在MySQL大小写敏感问题分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答MySQL大小写敏感问题分析的疑惑有所帮助!接下来,请跟着小编一起来学习吧! 〇
这篇文章主要介绍“MySQL大小写敏感问题分析”,在日常操作中,相信很多人在MySQL大小写敏感问题分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL大小写敏感问题分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧! 〇 lower_case_file_system 该参数是用于描述data目录所在的操作系统是否为大小写敏感,该参数为bool类型,但无法修改。 0 -- 大小写敏感 1 -- 大小写不敏感 比如跑在linux上的都是OFF或者0。 〇 lower_case_table_names 该参数为静态,可设置为0、1、2。 0 -- 大小写敏感。(Unix,Linux默认) 创建的库表将原样保存在磁盘上。如create database TeSt;将会创建一个TeSt的目录,create table AbCCC ...将会原样生成AbCCC.frm。 SQL语句也会原样解析。 1 -- 大小写不敏感。(Windows默认) 创建的库表时,MySQL将所有的库表名转换成小写存储在磁盘上。 SQL语句同样会将库表名转换成小写。 如需要查询以前创建的Test_table(生成Test_table.frm文件),即便执行select * from Test_table,也会被转换成select * from test_table,致使报错表不存在。 2 -- 大小写不敏感(OS X默认) 创建的库表将原样保存在磁盘上。 但SQL语句将库表名转换成小写。 修改lower_case_table_names导致的常见不良隐患: 如果在lower_case_table_names=0时,创建了含有大写字母的库表,改为lower_case_table_names=1后,则会无法被查到。 注意事项: 将默认的lower_case_tables_name为0设置成1,需先将已经存在的库表名转换为小写: 1)针对仅表名存在大写字母的情况: ①、lower_case_tables_name=0时,执行rename table成小写。 ②、设置lower_case_tables_name=1,重启生效。 2)针对库名存在大写字母的情况: ①、lower_case_tables_name=0时,使用mysqldump导出,并删除老的数据库。 ②、设置lower_case_tables_name=1,重启生效。 ③、导入数据至实例,此时包含大写字母的库名已转换为小写。 到此,关于“MySQL大小写敏感问题分析”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章! (编辑:站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |