如何为laravel查询添加整理

时间:2013-10-22 09:40:19

标签: php mysql laravel laravel-4 eloquent

我需要运行collate utf8_bin这样的查询:

SELECT * FROM `table` WHERE `field`='value' collate utf8_bin;

这仅适用于管理脚本,我不想更新表charset本身,仅针对特定查询。

我可以使用Eloquent ORM执行此操作,还是需要编写此查询?

3 个答案:

答案 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));