我遷移我的應用程序Laravel 4,但我被困在一個非常重要的查詢,原始查詢的是:在Laravel查詢生成器parenteses有
'select m.* from vn_mensagem m'
. ' INNER JOIN vn_mensagem_item i ON i.mensagem_id = m.mensagem_id '
. 'INNER JOIN vn_mensagem_destino d ON d.mensagem_id = m.mensagem_id '
. 'WHERE d.usuario_id = ' . $user->id . ' AND m.lida = 0 '
. 'AND i.data > "' . $timestamp . '" '
. 'group by d.mensagem_id '
. 'HAVING (count(i.mensagem_item_id) > 1 OR m.usuario_id != ' . $user->id . ')'
. 'ORDER BY i.data DESC'
我試圖重現該查詢與Laravel查詢生成器,我得到這個:
$mensagens = DB::table('mensagem')
->select('mensagem.*')
->join('mensagem_item', 'mensagem.mensagem_id', '=', 'mensagem_item.mensagem_id')
->join('mensagem_destino', 'mensagem.mensagem_id', '=', 'mensagem_destino.mensagem_id')
->where('mensagem_destino.usuario_id', $user->id)
->where('lida', 0)
->where('mensagem_item.data', '>', $timestamp)
->groupBy('mensagem_destino.mensagem_id')
->having(function($query) {
$query->where(DB::raw('count(mensagem_item.mensagem_item_id)'), '>', 1)
->orWhere('mensagem.usuario_id', '!=', $user->id);
})
->orderBy('mensagem_item.data', 'desc')->get();
但後來我得到了以下錯誤:
{"error":{"type":"ErrorException","message":"strtolower() expects parameter 1 to be string, object given","file":"\/var\/www\/laravel\/php\/vendor\/laravel\/framework\/src\/Illuminate\/Database\/Grammar.php","line":49}}
如何我可以在Laravel查詢生成器中的小菜單之間做出HAVING條件嗎?
完美地工作,謝謝! – wiLLiamcastrO