Я пытаюсь понять, как я могу преобразовать SQL-запрос в стиль построителя запросов в laravel.
Мой SQL-запрос:
$tagid = Db::select("SELECT `id` FROM `wouter_blog_tags` WHERE `slug` = '".$this->param('slug')."'");
$blog = Db::select("SELECT *
FROM `wouter_blog_posts`
WHERE `published` IS NOT NULL
AND `published` = '1'
AND `published_at` IS NOT NULL
AND `published_at` < NOW()
AND (
SELECT count( * )
FROM `wouter_blog_tags`
INNER JOIN `wouter_blog_posts_tags` ON `wouter_blog_tags`.`id` = `wouter_blog_posts_tags`.`tags_id`
WHERE `wouter_blog_posts_tags`.`post_id` = `wouter_blog_posts`.`id`
AND `id`
IN (
'".$tagid[0]->id."'
)) >=1
ORDER BY `published_at` DESC
LIMIT 10
OFFSET 0");
Теперь я заканчиваю преобразование в построитель запросов:
$test = Db::table('wouter_blog_posts')
->where('published', '=', 1)
->where('published', '=', 'IS NOT NULL')
->where('published_at', '=', 'IS NOT NULL')
->where('published_at', '<', 'NOW()')
->select(Db::raw('count(*) wouter_blog_tags'))
->join('wouter_blog_posts_tags', function($join)
{
$join->on('wouter_blog_tags.id', '=', 'wouter_blog_posts_tags.tags_id')
->on('wouter_blog_posts_tags.post_id', '=', 'wouter_blog_posts.id')
->whereIn('id', $tagid[0]->id);
})
->get();
Я читал, что не могу использовать whereIn в соединении. Ошибка, которую я теперь получаю:
Вызов неопределенного метода Illuminate\Database\Query\JoinClause::whereIn()
Я действительно не знаю, как я могу преобразовать свой SQL в построитель запросов. Надеюсь, когда я увижу хорошее рабочее преобразование моего запроса, я смогу понять, как мне это сделать в следующий раз.
->whereRaw('id IN ?', [$tagid[0]->id])
. Просто убедитесь, что параметр привязки в конце является массивом. Однако я не знаю, почему вы используете WHERE IN для одного значения -$tagid[0]->id
. Это возвращает массив или что-то в этом роде? Вот альтернативное решение stackoverflow.com/questions/26913776/ - person Yasen Slavov   schedule 12.09.2015