- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我在“utf8 -- UTF-8 Unicode”中有一个模式作为字符集和“utf8_spanish_ci”的排序规则。
所有内部表都是 InnoDB,具有与上述相同的字符集和排序规则。
问题来了:
像这样的查询
SELECT *
FROM people p
WHERE p.NAME LIKE '%jose%';
我得到 83 个结果行。我应该有 84 个结果,因为我知道。
更改位置:
WHERE p.NAME LIKE '%JOSE%';
我得到完全相同的 83 行。使用 JoSe、Jose、JOSe 等组合。报告所有相同的 83 行。
当游戏中出现口音时,问题就来了。如果这样做:
WHERE p.NAME LIKE '%josé%';
我没有得到任何结果。 0 行。
但如果我这样做:
WHERE p.NAME LIKE '%JOSÉ%';
我只得到一个结果行,所以 1 行。这是唯一带有重音“jose”并大写的行。
我已经尝试过使用 josÉ、JoSÉ 或我所做的任何组合,只要重音字母保持大写或不大写,因为它确实存储在数据库中并且它仍然返回唯一的行。如果我突然将“É”更改为“é”,无论我在 JOSE 中对大写进行何种组合,它都不会返回任何行。
所以结论:
我想要什么?
LIKE
上的COLLATION
等解决方案对我不起作用,不知道为什么...
我能做什么?
编辑:
如果我这样做:
WHERE p.NAME LIKE '%jose%' COLLATE utf8_general_ci;
我得到错误:
COLLATION 'utf8_general_ci' is not valid for CHARACTER SET 'latin1'
而且我还更改了列上所有可能的排序规则!
如果我做类似的事情:
WHERE p.NAME LIKE _utf8 '%jose%' COLLATE utf8_general_ci;
报同样的83行,好像我什么都没弄...
最佳答案
您已经尝试使用不区分重音的排序规则进行搜索和排序。
http://dev.mysql.com/doc/refman/5.0/en/charset-collation-implementations.html
问题是,您的 NAME
列似乎存储在 latin1(8 位)字符集中。这就是为什么 mySQL 会这样对你发牢骚:
COLLATION 'utf8_general_ci' is not valid for CHARACTER SET 'latin1'
如果你尝试,你可能会得到你想要的结果
WHERE CONVERT(p.NAME USING utf8) LIKE _utf8 '%jose%' COLLATE utf8_general_ci;
但是,要小心!
当您在 WHERE 语句中的列上使用任何类型的函数(在此示例中为 CONVERT)时,您会挫败 MySQL 使用索引优化搜索的尝试。如果这个项目变得很大(也就是说,如果您的表中有很多行),您需要以 utf8 格式存储数据,而不是 latin1。 (您可能已经知道您的 LIKE '%whatever%'
搜索词也会破坏 MySQL 的索引。)
关于mysql - MySQL 如何在 UTF-8 中工作 "case insensitive"和 "accent insensitive",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10831076/
我经常在 ATS 中看到使用 case、case+ 或 case- 形成的 case 表达式。有什么区别? 最佳答案 如果表达式不详尽,使用 case 会发出警告,case+ 会产生错误,而 case
我有一个导入时全部大写的表,我想将其转换为正确的大小写。你们用什么脚本来完成这个? 最佳答案 这个函数: “正确大小写”由空格分隔的所有“大写”单词 保留“小写单词” 即使对于非英语字母也能正常工作
#include int main() { switch(2) { case 1: if(1)
我已经四处寻找了一段时间,如果我使用的术语不当,请原谅我... 代码的目标是在输入为 0 时更新 Aout1 和 Aout0,输出对应于 7 段显示,但出现以下错误: “错误 (10170):Four
我正在尝试按照 PostgreSQL 手册中的说明进行操作。 PostgreSQL: Documentation: 9.1: Control Structures 我的 PostgreSQL 服务器是
我有一个状态机,其中有几个非常相似的状态。我可以为每个状态编写它,如下例所示: module CHECK_FSM ( GO, DONE, CLK, RESETN ); input GO;
如何使用或创建案例? 就像是: string str; case (str) "abc" || "dfg": begin //some code end "yfg":
这个问题已经有答案了: Are double and single quotes interchangeable in JavaScript? (23 个回答) 已关闭 9 年前。 我正在学习Java
汽车 Make | Model | Year | Color Honda | Accord | 12 | Red Lexus | IS | 14 |
如何使用当前 case 语句的值跳转到 switch-case 条件下的另一个 case 语句? 是否可以使用 switch case 来实现这种事情,或者是否有其他实现方式? 有可能实现吗?如果没有
我理解下面的代码。 var day = 2; switch (day) { case 1: document.write("Monday"); break;
这是有效的。 object FilesToDFDS { case class Student(id: Int, name: String, dept:String) def main(
我对 VHDL 还是个新手。我需要在 CASE 语句中为多个信号赋值,如下所示: CASE input24 IS WHEN "00" THEN output0
我有这个 case 语句,它给出了一个错误“变量 constant1 未使用”。它似乎忽略了变量并返回了第一行,因此变量显然没有范围。如果我用数字 1 替换常量,那么它就可以工作。在 Elixir 中
在 MySQL 中,是否可以在 SELECT 子句中有两个 CASE 语句,其中第二个 CASE 语句依赖于第一个 CASE 语句? 例如,考虑以下查询: SELECT CASE WHEN `user
我正在尝试一个挑战,我需要获得一个随机数,并在没有重复的情况下打印数字内的数字总和:例如,123 将打印 6 ( 1 + 2 + 3 ),而 32111 将做同样的事情(因为我们没有在我们的总和中添加
当有人试图更新当前未存储在我的散列中的值时,我想立即返回 when 'add' 而无需重新启动整个 case声明,因为我已经知道他们想要添加并且不想再次提示他们。 有没有一种方法可以在不重新启动整个案
老 C 程序员可以在 Swift 方面得到一些帮助。 我不太了解 if-case 语法。例如: if case 20...30 = age { print ("in range.") } cas
老 C 程序员可以在 Swift 方面得到一些帮助。 我不太了解 if-case 语法。例如: if case 20...30 = age { print ("in range.") } cas
我有一个 ArrayList,其中包含以下字符串:[name, age, gender, salary] . 有没有办法可以将 ArrayList 中的值用作 case 表达式? 显而易见的答案是否定
我是一名优秀的程序员,十分优秀!