zoukankan      html  css  js  c++  java
  • MySQL数据库like查询中文出现不准确的解决方法

    MySQL数据库like查询中文出现不准确的解决方法

    Mysql数据库like查询中文出现不准确的解决方法,中文检索有时候有点蛋疼,Mysql数据库like查询中文有时候会出现不准确。而且,在进行like检索时,有时候会返回一些与查询词不相关的记录,如查找 “%s%” 时,返回的结果中可能有中文字符,却没有s字符存在,这与数据库中文编码规则有关。

    如希望查找title中含有字母s的所有新闻:  

    select * from test.news where title like '%s%'

    返回的结果中有一些包含s,而有些则只有中文,很郁闷(也很邪恶,嘿嘿)。

    测试了下,发现一种解决方法,就是使用 BINARY(是CAST(str AS BINARY)简短写法) 强制转换进行检索

    select * from test.news where binary title like '%s%'

    这样结果就比较准确了,但还有一个问题,就是字母区分大小写,检索的时候依然不正确,只好再转化一下了:

    select * from test.news where binary ucase(title) like  '%s%'

    如此,临时解决办法搞定,不过速度会变慢,希望以后的mysql版本能解决掉此问题

  • 相关阅读:
    cookie 和 session 和 session id
    getMasterRequest VS getCurrentRequest?
    drupal 7 watchdog 记录debug信息
    刷环境
    再进一步
    7zip 不见 .git
    为什么我记不住密码
    www / publish
    behat debug / class property
    drupal 网站Log
  • 原文地址:https://www.cnblogs.com/lh123/p/3885151.html
Copyright © 2011-2022 走看看