我需要运行collate utf8_bin
这样的查询:
SELECT * FROM `table` WHERE `field`='value' collate utf8_bin;
这仅适用于管理脚本,我不想更新表charset本身,仅针对特定查询。
我可以使用Eloquent ORM执行此操作,还是需要编写此查询?
答案 0 :(得分:7)
如果它可以解决您的问题,您可以这样做:
SomeModel::whereField($value)->orderByRaw("name COLLATE utf8_bin ASC")->get();
答案 1 :(得分:5)
由于您可以配置MySQL驱动程序使用一个:
'mysql' => array(
'driver' => 'mysql',
'host' => 'localhost',
'database' => 'database',
'username' => 'root',
'password' => '',
'charset' => 'utf8',
'collation' => 'utf8_unicode_ci',
'prefix' => '',
),
您可以为特定查询创建不同的连接:
'mysql-collation' => array(
'driver' => 'mysql',
'host' => 'localhost',
'database' => 'database',
'username' => 'root',
'password' => '',
'charset' => 'utf8',
'collation' => '<your collation>',
'prefix' => '',
),
在查询中使用该连接:
$users = DB::connection('mysql-collation')->select(...);
修改强>
在模型上,您可能能够以这种方式设置连接:
$posts = new Word;
$posts->setConnection('mysql-collation');
$posts->where(...);
答案 2 :(得分:1)
如果只需要将其应用于WHERE子句中的值:
$value = "àBc123";
$query->whereRaw('field_name COLLATE utf8mb4_bin = (?)', $value);
utf8mb4_bin
)替换utf8_bin
。(?)
应该利用Laravel的查询清理功能。对于区分重音,但不区分大小写:
$value = "àBc123";
$query->whereRaw('LOWER(field_name) COLLATE utf8mb4_bin = (?)', strtolower($value));