在Laravel 4迁移中创建MYSQL功能

时间:2017-01-10 15:26:24

标签: php mysql laravel laravel-4 laravel-migrations

我正在研究laravel 4.1。我想通过迁移创建MYSQL函数,但它不能与php artisan migrate一起使用。即使它在控制台中显示Migrated: 2017_01_10_140002_create_MYSQL_UNAVAILABLE_PRODS_FUNCTION。当我在MYQL客户端中复制/过去相同的创建代码时,它可以工作并创建函数。当我运行php artisan migrate:rollback时,该功能被删除 任何帮助将不胜感激。

迁移文件:

<?php

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateMYSQLUNAVAILABLEPRODSFUNCTION extends Migration
{

    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        $available = Constant::PRODUCT_AVAILABLE_TRUE | Constant::PRODUCT_AVAILABLE_STOCK_TRUE;

        $sql = 'DROP FUNCTION IF EXISTS UNAVAILABLE_PRODS;
                DELIMITER $$
                CREATE FUNCTION UNAVAILABLE_PRODS(CONFIG_ID INT, PROD_TYPE INT)
                  RETURNS TEXT
                  LANGUAGE SQL
                BEGIN
                    DECLARE RES TEXT;

                    SET GROUP_CONCAT_MAX_LEN = 2048;

                    SET RES = (SELECT GROUP_CONCAT(ID SEPARATOR \'|\') FROM PRODUCT_BASE WHERE `PRODUCT_TYPE` & PROD_TYPE AND `PRODUCT_BASE`.`AVAILABLE` <> ' . $available . ');

                    RETURN CONCAT(CONFIG_ID, \'=(\', RES, \')\');
                END;
                $$
                DELIMITER ;
                ';

        DB::unprepared($sql);
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        DB::unprepared('DROP FUNCTION IF EXISTS UNAVAILABLE_PRODS;');
    }

}

2 个答案:

答案 0 :(得分:3)

我弄清楚问题是什么,它是分隔符。 删除了DELIMITER $$$$DELIMITER ;

后,它才有效

答案 1 :(得分:0)

我认为这里的错误是\'|\')这个引号在你的sql之外(没有绿色)。所以php试图以某种方式执行它们screenshot of your code