tianlunvip 2019-12-27 23:55 采纳率: 100%
浏览 487
已采纳

mysql 插入字符有问题

mysql 插入字符问题,因为有一个字段我作了key,不能有重复数据,

在字段添加 a 字符后无法再添加 á 字符,提示

1062 - Duplicate entry 'á' for key 'chars'

**á ** 带声调的属于HTML实体字符,难道mysql认为 a 和 á 是一样的编码?

而且取 a 数据的时候 ,也会把 á 的数据取出来。

使用的服务器版本: 5.7.20 - MySQL Community Server 字符编码采用 UTF-8

  • 写回答

2条回答 默认 最新

  • 青鬆下的坚躯 2019-12-30 23:46
    关注

    可以了解一下mysql的COLLATE(效验规则)。默认的XXX_ci 是不区分大小写和是否携带声调的 。
    只要把对应的字段或表的校验规则COLLATE设置为XXX_bin就会解决你说的问题。

    比如:key varchar(255) COLLATE utf8_bin

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵