在 PHP 5.4 中,將會有 createCollation 方法來使用您的自訂排序方法,以便能夠使用 Unicode 對資料集進行排序,如下所示
<?php
setlocale(LC_COLLATE, 'fr_FR.UTF-8');
$db->createCollation('PHP_COLLATE', 'strcoll');
$db->query('SELECT * FROM my_table ORDER BY name COLLATE PHP_COLLATE;');
?>
但在這個酷炫的功能可用之前,您必須做一些技巧,例如像這樣處理法文
<?php
function sqlite3_to_ascii($str, $charset = 'UTF-8')
{
if (!trim($str))
return $str;
if (preg_match('!^[[:ascii:]]+$!', $str))
return $str;
$str = htmlentities($str, ENT_NOQUOTES, $charset);
$str = preg_replace('#&([A-za-z])(?:acute|cedil|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $str);
$str = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $str);
$str = preg_replace('#&[^;]+;#', '', $str);
return $str;
}
$db->createFunction('to_ascii', 'sqlite3_to_ascii', 1);
$res = $db->query('SELECT * FROM test ORDER BY to_ascii(text);');
?>
這會在排序之前將非 ASCII 字元轉換為 ASCII 字元。實際上,這不適用於非拉丁語系的語言,但對於拉丁語系的語言來說,總比沒有好。
請注意,這會讓查詢速度降低約 1.8 倍(在 10,000 列的表格上測試)。