[英]How to execute a raw sql query with multiple statement with laravel
无论如何,我可以使用laravel框架使用如下所示的多个语句执行查询。 我曾尝试使用DB::statement
但返回了一个 sql 语法错误,但是当我在 phpmyadmin 上执行相同的查询时,我工作了,这太令人沮丧了。 请帮我。
LOCK TABLE topics WRITE;
SELECT @pRgt := rgt FROM topics WHERE id = ?;
UPDATE topics SET lft = lft + 2 WHERE rgt > @pRgt;
UPDATE topics SET rgt = rgt + 2 WHERE rgt >= @pRgt;
INSERT INTO topics (title, overview, article, image, lft, rgt)
VALUES (?, ?, ?, ?, @pRgt, @pRgt + 1);
UNLOCK TABLES;
DB::unprepared()
unprepared DB::unprepared()
应该可以解决问题,laravel 准备并为 sql 查询做一些事情。
但是,您可以使用DB::unprepared
使用绝对原始的。
例如
DB::unprepared('LOCK TABLE topics WRITE;
SELECT @pRgt := rgt FROM topics WHERE id = ?;
UPDATE topics SET lft = lft + 2 WHERE rgt > @pRgt;
UPDATE topics SET rgt = rgt + 2 WHERE rgt >= @pRgt;
INSERT INTO topics (title, overview, article, image, lft, rgt)
VALUES (?, ?, ?, ?, @pRgt, @pRgt + 1);
UNLOCK TABLES;');
无论是单个/多个语句,它都会执行您的整个 SQL 查询。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.