douqiao6015 2014-06-29 14:07
浏览 428
已采纳

在Laravel的Eloquent whereIn方法中的原始声明

I would simply like to run such query:

select * from `users` where SUBSTRING_INDEX(`email`, '@' ,-1) not in ('gmail.com, outlook.com');

Two ways crossed my mind which non of them work:

1

$providers = array('gmail.com', 'outlook.com');

$providers = "'" . implode("', '", $providers) . "'";

User::whereRaw("SUBSTRING_INDEX(`email`, '@' ,-1) not in (?)", $providers);

the above would not work because PDO will escape the "'" characters.

2

User::whereIn(DB::raw("SUBSTRING_INDEX(`email`, '@' ,-1)", $providers);

this one simply does not work. any idea?

  • 写回答

3条回答 默认 最新

  • duanniu4106 2014-06-29 15:12
    关注

    Here's a safer way to do it:

    $providers = ['gmail.com', 'outlook.com'];
    
    $placeholder = implode(', ', array_fill(0, count($providers), '?'));
    
    User::whereRaw("SUBSTRING_INDEX(`email`, '@' ,-1) not in ($placeholder)", $providers);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?