gpt4 book ai didi

php - Laravel 5.1 如何使用迁移创建 MySQL 存储过程

转载 作者:可可西里 更新时间:2023-11-01 06:31:46 25 4
gpt4 key购买 nike

您好,我正在尝试使用 Laravel 5.1 迁移创建一个存储过程。到目前为止,我尝试使用 DB::connection()->getPdo()->exec()、DB::raw() 和 DB::unprepared(),但没有成功。这是我的代码的样子:

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
use Wryttnapp\Models\User;


class AddCentroidFieldsToUsersTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
DB::connection()->getPdo()->exec("
ALTER TABLE `users`
ADD COLUMN centroid POINT NULL
AFTER `avatar`;");

DB::unprepared("SET @OLD_SQL_MODE=@@SQL_MODE;

DELIMITER ;;

DROP PROCEDURE IF EXISTS UPDATE_USER_CENTROID;;

CREATE PROCEDURE UPDATE_USER_CENTROID(userId INT)
NOT DETERMINISTIC
BEGIN
DECLARE bDone INT;

DECLARE tempLatLon VARCHAR(100);
DECLARE counter INT;
DECLARE firstLatLon VARCHAR(100);
DECLARE polygonDefinition TEXT;
DECLARE geometry POINT;

DECLARE curs CURSOR FOR SELECT DISTINCT CONCAT(`latitude`, ' ', `longitude`) FROM `user_locations` WHERE `user_id` = userId ORDER BY `id` ASC;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET bDone = 1;

OPEN curs;

SET bDone = 0;
SET counter = 0;
SET polygonDefinition = ',';
FETCH curs INTO tempLatLon;

WHILE NOT bDone DO
SET polygonDefinition = CONCAT(polygonDefinition, ',', tempLatLon);

IF counter = 0 THEN
SET firstLatLon = tempLatLon;
END IF;
SET counter = counter + 1;

FETCH curs INTO tempLatLon;
END WHILE;

CLOSE curs;

SET polygonDefinition = CONCAT(polygonDefinition, ',', firstLatLon);
SET polygonDefinition = SUBSTRING(polygonDefinition, 3);
SET polygonDefinition = CONCAT('POLYGON((', polygonDefinition, '))');

SET geometry = ST_Centroid(ST_GeomFromText(polygonDefinition));

UPDATE `users` SET centroid = geometry WHERE id = userId;
END;;

DELIMITER ;
");
}

/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
DB::connection()->getPdo()->exec("
ALTER TABLE `users` DROP COLUMN centroid;
DROP INDEX centroid_index ON `users`;
DROP FUNCTION IF EXISTS `UPDATE_USER_CENTROID`;");
}
}

求助!谢谢!

最佳答案

到目前为止,这就是我执行迁移程序的方式...我相信我在设置分隔符时遇到了一些问题,所以我放弃了它们并为每个语句使用了不同的 unprepared()

$procedure = "
CREATE PROCEDURE `procedure_name`(procedure_param_1 TEXT, procedure_param_2 TEXT)
BEGIN
// Your SP here
END
";

DB::unprepared("DROP procedure IF EXISTS procedure_name");
DB::unprepared($procedure);

这似乎是相关的:Laravel migration raw sql error

关于php - Laravel 5.1 如何使用迁移创建 MySQL 存储过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35547868/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com