最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL对大小写敏感一些总结

来源:动视网 责编:小采 时间:2020-11-09 09:53:10
文档

MySQL对大小写敏感一些总结

MySQL对大小写敏感一些总结:MySQL的大小写敏感其实是根据用户的操作系统来的,可以强制以 -O lower_case_table_names=1 参数启动 mysqld(如果使用 --defaults-file=...\\my.cnf 参数来读取指定的配置文件启动 mysqld 的话,你需要在配置文件的 [mysqld] 区段下增加一
推荐度:
导读MySQL对大小写敏感一些总结:MySQL的大小写敏感其实是根据用户的操作系统来的,可以强制以 -O lower_case_table_names=1 参数启动 mysqld(如果使用 --defaults-file=...\\my.cnf 参数来读取指定的配置文件启动 mysqld 的话,你需要在配置文件的 [mysqld] 区段下增加一


MySQL的大小写敏感其实是根据用户的操作系统来的,可以强制以 -O lower_case_table_names=1 参数启动 mysqld(如果使用 --defaults-file=...\\my.cnf 参数来读取指定的配置文件启动 mysqld 的话,你需要在配置文件的 [mysqld] 区段下增加一行 lower_case_tabl

这样MySQL 将在创建与查找时将所有的表名自动转换为小写字符(这个选项缺省地在 Windows 中为 1 ,在 Unix 中为 0。从 MySQL 4.0.2 开始,这个选项同样适用于数据库名)。

当你更改这个选项时,你必须在启动 mysqld 前首先将老的表名转换为小写字母。

换句话说,如果你希望在数据库里面创建表的时候保留大小写字符状态,则应该把这个参数置0: lower_case_table_names=1 。

否则的话你会发现同样的sqldump脚本在不同的操作系统下最终导入的结果不一样(在Windows下所有的大写字符都变成小写了)。

注意:

在Win32上,尽管数据库和表名是忽略Mysql大小写的,你不应该在同一个查询中使用不同的大小写来引用一个给定的数据库和表。下列查询将不工作,因为它作为my_table和作为MY_TABLE引用一个表:

代码如下

  1.Mysql> SELECT * FROM my_table WHERE MY_TABLE.col=1;

2、列名

  列名在所有情况下都是忽略大小写的。

3、表的别名

  表的别名是区分大小写的。下列查询将不工作,: 因为它用a和A引用别名:

代码如下

  1.Mysql> SELECT col_name FROM tbl_name AS a

  2.WHERE a.col_name = 1 OR A.col_name = 2;

4、列的别名

  列的别名是忽略大小写的。

5、字符串比较和模式匹配

  缺省地,Mysql搜索是大小写不敏感的(尽管有一些字符集从来不是忽略Mysql大小写的,例如捷克语)。这意味着,如果你用col_name LIKE 'a%'搜寻,你将得到所有以A或a开始的列值。如果你想要使这个搜索大小写敏感,使用象INDEX(col_name, "A")=0检查一个前缀。或如果列值必须确切是"A",使用STRCMP(col_name, "A") = 0。

  简单的比较操作(>=、>、= 、< 、<=、排序和聚合)是基于每个字符的“排序值”。有同样排序值的字符(象E,e)被视为相同的字符!

  LIKE比较在每个字符的大写值上进行(“E”=”e”)。

  如果你想要一个列总是被当作Mysql大小写敏感的方式,声明它为BINARY。

例如:

代码如下


  1.Mysql> SELECT "E"="e","E"=BINARY "e";
  2.+---------+----------------+| "E"="e" | "E"=BINARY "e"
  |+---------+----------------+| 1 | 0 |+---------+----------------+

文档

MySQL对大小写敏感一些总结

MySQL对大小写敏感一些总结:MySQL的大小写敏感其实是根据用户的操作系统来的,可以强制以 -O lower_case_table_names=1 参数启动 mysqld(如果使用 --defaults-file=...\\my.cnf 参数来读取指定的配置文件启动 mysqld 的话,你需要在配置文件的 [mysqld] 区段下增加一
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top