簡體   English   中英

如何將整理添加到 Laravel 查詢

[英]How to add collate to laravel query

我需要運行一個像這樣collate utf8_bin的查詢:

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

這是嚴格的管理腳本,我不想更新表字符集本身,只是為了特定的查詢。

我可以使用 Eloquent ORM 來做到這一點還是我需要寫出這個查詢?

如果它解決了您的問題,您可以這樣做:

SomeModel::whereField($value)->orderByRaw("name COLLATE utf8_bin ASC")->get();

由於您可以將 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(...);

如果您只需要將此應用於 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));

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM