douxuanyi2813 2016-11-01 21:10
浏览 40
已采纳

从几个输出中选择一个在mysql中具有特殊字符的输出

In my database I have two forms of the same word. So for example when I search for amor I get amor and āmōr. How can I fetch just āmōr from the database.

  • 写回答

1条回答 默认 最新

  • doudeng2025 2016-11-01 21:35
    关注

    If you don't want to mess around with Collation (for some reason):

    SELECT a.text
    FROM table a
    WHERE a.text = 'amor'
    AND BINARY(a.text) = BINARY('amor')
    

    I left the first condition with the plain text so that MySQL can use an index on text, in case that exists. The second condition will make sure you are only getting the exact text (including capitalization) you searched for.

    EDIT: Based on comment.

    If you do want to get the accented result, you need to use a collation that ignores such accents. The one you need to use depends on the collation of the column..

    Try any of the below:

    SELECT a.text
    FROM table a
    WHERE a.text = 'amor'
    COLLATE 'utf8_general_ci';
    

    Or:

    SELECT a.text
    FROM table a
    WHERE a.text = 'amor'
    COLLATE 'latin1_general_ci';
    

    EDIT #2: Based on more comments.

    To always get the accented version in case there is more than one match:

    SELECT a.text
    FROM table a
    WHERE a.text = 'amor' -- this condition returns both results
    ORDER BY LENGTH(BINARY(a.text)) DESC
    LIMIT 1
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 自适应 LMS 算法实现 FIR 最佳维纳滤波器matlab方案
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥15 Python3.5 相关代码写作
  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像