基于mysql 默认排序规则的坑

作者:陌下微尘 时间:2024-01-17 11:38:56 

mysql默认varchar类型是对大小写不敏感(不区分),如果想要mysql区分大小写需要设置排序规则:

utf8_bin将字符串中的每一个字符用二进制数据存储,区分大小写。

utf8_genera_ci不区分大小写,ci为case insensitive的缩写,即大小写不敏感。

utf8_general_cs区分大小写,cs为case sensitive的缩写,即大小写敏感。

用utf8_genera_ci没有区分大小写,导致这个字段的内容区分大小写时出问题,比如作为区分大小写的code或者验证码时就出问题了。

utf8_general_cs这个选项一般没有,所以只能用utf8_bin区分大小写。

1)设置排序规则是可逆的,如果之前设置的排序规则不符合,更换排序规则后,可能出现乱码,当再次恢复原来的排序规则后,乱码即消失。

2)可以将varchar 类型改为 varbinary

3)如果已经使用了默认的排序规则,即utf8_genera_ci,而又想查询结果大小写区分,可以在查询时进行限定:


select binary column from table;

或者


select column2 from table where binary cloumn;

补充:mysql中的字符集和排序规则

字符集:

字符是各种文字和符号的总称,字符集就是字符的集合。常见字符集名称:ASCII字符集、GB2312字符集、BIG5字符集、GB18030字符集、Unicode字符集等。

计算机要识别各种字符集文字,就需要字符编码。所以有些字符集一个字符是2个字节,有些字符集一个字符是3个字节。

排序规则:举例

utf_bin和utf_general_ci这两者到底有什么区别。

ci是case insensitive, 即"大小写不敏感",a 和 A 会在字符判断中会被当做一样的;

bin是二进制, a 和A 会别区别对待.

utf8_general_ci不区分大小写,这个你在注册用户名和邮箱的时候就要使用。

utf8_general_cs区分大小写,如果用户名和邮箱用这个 就会照成不良后果

utf8_bin:字符串每个字符串用二进制数据编译存储。区分大小写,而且可以存二进制的内容

所以排序规则主要说明了是否大小写敏感和存储方式。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

来源:https://blog.csdn.net/qq_33045443/article/details/88670154

标签:mysql,默认,排序
0
投稿

猜你喜欢

  • Python文件读取的3种方法及路径转义

    2021-12-27 03:48:28
  • linux下perl操作mysql数据库(需要安装DBI)

    2024-01-15 09:32:50
  • python configparser中默认值的设定方式

    2023-09-08 22:01:33
  • 培养色感的一些经验分享

    2013-11-10 03:47:03
  • 教你制作IBM LOGO的方法

    2007-10-23 13:34:00
  • Python入门篇之函数

    2023-03-10 05:41:00
  • Python创建7种不同的文件格式的方法总结

    2021-01-24 03:13:51
  • Python中的字符串类型基本知识学习教程

    2023-03-29 01:48:47
  • 利用J2ME与ASP建立数据库连接

    2010-04-03 20:53:00
  • 一个统计当前在线用户的解决方案

    2007-10-13 19:27:00
  • Laravel实现队列的示例代码

    2023-05-28 04:39:21
  • 利用js实现简易红绿灯

    2024-04-22 22:30:02
  • 如何使用python docx模块操作word文档

    2022-04-23 12:16:02
  • python区块链实现简版网络

    2023-02-17 01:06:59
  • python中pandas操作apply返回多列的实现

    2023-03-04 06:46:44
  • 用Python代码来解图片迷宫的方法整理

    2023-03-17 18:35:43
  • Python3.5内置模块之time与datetime模块用法实例分析

    2023-11-02 23:25:35
  • Laravel配置全局公共函数的方法步骤

    2023-11-15 01:20:42
  • pygame游戏之旅 调用按钮实现游戏开始功能

    2023-04-19 06:36:44
  • python输入、数据类型转换及运算符方式

    2021-08-09 19:20:17
  • asp之家 网络编程 m.aspxhome.com