在 Laravel 4 迁移中创建 MYSQL 函数
Creating MYSQL FUNCTION in Laravel 4 Migrations
我正在研究 laravel 4.1。我想通过迁移创建 MYSQL 函数,但它不适用于 php artisan migrate
。即使它在控制台中显示 Migrated: 2017_01_10_140002_create_MYSQL_UNAVAILABLE_PRODS_FUNCTION
。当我 copy/past 在 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;');
}
}
我认为错误在这里\'|\')
这个引号在你的sql之外(没有绿色)。所以 php 尝试以某种方式执行它们 screenshot of your code
我知道问题出在哪里了,是分隔符。
在我删除 lignes DELIMITER $$
, $$
和 DELIMITER ;
后它起作用了
我正在研究 laravel 4.1。我想通过迁移创建 MYSQL 函数,但它不适用于 php artisan migrate
。即使它在控制台中显示 Migrated: 2017_01_10_140002_create_MYSQL_UNAVAILABLE_PRODS_FUNCTION
。当我 copy/past 在 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;');
}
}
我认为错误在这里\'|\')
这个引号在你的sql之外(没有绿色)。所以 php 尝试以某种方式执行它们 screenshot of your code
我知道问题出在哪里了,是分隔符。
在我删除 lignes DELIMITER $$
, $$
和 DELIMITER ;