From 2bdeb8ef3026a12daef0f3e4534c101d27c24c57 Mon Sep 17 00:00:00 2001 From: David Monllao Date: Fri, 18 Sep 2015 11:42:12 +0800 Subject: [PATCH] MDL-51052 dml: More info about mysql and case & accent sensitiveness --- lib/dml/mysqli_native_moodle_database.php | 28 +++++++++++++++-------- 1 file changed, 18 insertions(+), 10 deletions(-) diff --git a/lib/dml/mysqli_native_moodle_database.php b/lib/dml/mysqli_native_moodle_database.php index 8c61536809ea2..70e8a6ed4bcb9 100644 --- a/lib/dml/mysqli_native_moodle_database.php +++ b/lib/dml/mysqli_native_moodle_database.php @@ -1502,10 +1502,13 @@ public function sql_cast_char2real($fieldname, $text=false) { /** * Returns 'LIKE' part of a query. * + * Note that mysql does not support $casesensitive = true and $accentsensitive = false. + * More information in http://bugs.mysql.com/bug.php?id=19567. + * * @param string $fieldname usually name of the table column * @param string $param usually bound query parameter (?, :named) * @param bool $casesensitive use case sensitive search - * @param bool $accensensitive use accent sensitive search (not all databases support accent insensitive) + * @param bool $accensensitive use accent sensitive search (ignored if $casesensitive is true) * @param bool $notlike true means "NOT LIKE" * @param string $escapechar escape char for '%' and '_' * @return string SQL code fragment @@ -1517,19 +1520,24 @@ public function sql_like($fieldname, $param, $casesensitive = true, $accentsensi $escapechar = $this->mysqli->real_escape_string($escapechar); // prevents problems with C-style escapes of enclosing '\' $LIKE = $notlike ? 'NOT LIKE' : 'LIKE'; + if ($casesensitive) { + // Current MySQL versions do not support case sensitive and accent insensitive. return "$fieldname $LIKE $param COLLATE utf8_bin ESCAPE '$escapechar'"; + + } else if ($accentsensitive) { + // Case insensitive and accent sensitive, we can force a binary comparison once all texts are using the same case. + return "LOWER($fieldname) $LIKE LOWER($param) COLLATE utf8_bin ESCAPE '$escapechar'"; + } else { - if ($accentsensitive) { - return "LOWER($fieldname) $LIKE LOWER($param) COLLATE utf8_bin ESCAPE '$escapechar'"; - } else { - // Set a case sensitive collation if using utf8_bin. - if ($this->get_dbcollation() == 'utf8_bin') { - return "$fieldname $LIKE $param COLLATE utf8_unicode_ci ESCAPE '$escapechar'"; - } else { - return "$fieldname $LIKE $param ESCAPE '$escapechar'"; - } + // Case insensitive and accent insensitive. + $collation = ''; + if ($this->get_dbcollation() == 'utf8_bin') { + // Force a case insensitive comparison if using utf8_bin. + $collation = 'COLLATE utf8_unicode_ci'; } + + return "$fieldname $LIKE $param $collation ESCAPE '$escapechar'"; } }