MySQL模糊匹配中文查询问题 dbutils

  • Post author:
  • Post category:mysql



今天遇到一个问题,MySQL中模糊匹配查询(like),使用的是dbutils


匹配查询英文、数字(学生id,学号,昵称)时没有问题,但匹配查询中文(学生姓名)时,查询不到结果


搞了好久,都没有解决,最后,看到一篇文章说是编码问题,豁然开朗,甚是无语


只要加上

?characterEncoding=UTF-8&useUnicode=true

就可以匹配查询中文了


感觉有些问题真的是知道就是几分钟的事,不知道搞再久也无济于事


需要学习的还要很多,努力!!!





添加

characterEncoding=UTF-8&useUnicode=true

的作用是:指定字符的编码、解码格式。



例如:mysql数据库用的是gbk编码,而项目数据库用的是utf-8编码。这时候如果添加了


useUnicode=true&characterEncoding=UTF-8 ,


那么作用有如下两个方面:



1. 存数据时:





数据库在存放项目数据的时候会先用UTF-8格式将数据解码成字节码,然后再将解码后的字节码重新使用GBK编码存放到数据库中。



2.取数据时:





在从数据库中取数据的时候,数据库会先将数据库中的数据按GBK格式解码成字节码,然后再将解码后的字节码重新





UTF-8格式编码数据,最后再将数据返回给客户端。



版权声明:本文为ltaihyy原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。