在 Laravel 4 迁移中创建 MYSQL FUNCTION

Posted

技术标签:

【中文标题】在 Laravel 4 迁移中创建 MYSQL FUNCTION【英文标题】:Creating MYSQL FUNCTION in Laravel 4 Migrations 【发布时间】:2017-05-25 03:36:12 【问题描述】:

我正在开发 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;');
    


【问题讨论】:

你为什么不使用 Eloquent? 我在 DB 中有一个名为 info 的字段,其数据格式为 config_id1=prod_id1|config_id2=prod_id2|... 所以不要使用 php 通过发送来进行一些测试数百个 ID 的列表.. 对于性能问题,最好在 MYSQL 端进行。我需要检查该字段是否具有来自值列表的一对 key=value,例如:41=(202|101..) 和:SELECT... WHERE info REGEXP UNAVAILABLE_PRODS(41, 64)。函数执行后的结果是这样的SELECT... WHERE info REGEXP '41=(prod_id1|prod_id2...)': 【参考方案1】:

我发现问题出在哪里,是分隔符。 在我移除了 DELIMITER $$$$DELIMITER ; 的 lignes 之后,它起作用了

【讨论】:

【参考方案2】:

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

【讨论】:

我用双引号替换了单引号,但仍然无法正常工作。如果这是问题所在,我会在控制台中显示错误。

以上是关于在 Laravel 4 迁移中创建 MYSQL FUNCTION的主要内容,如果未能解决你的问题,请参考以下文章

在 Laravel 迁移中创建一个具有自定义大小的小整数列

如何从迁移中创建 Laravel 模型?

Laravel 在特定文件夹中创建迁移文件

Laravel 不会在刷新时在“迁移”表中创建记录

如何在 Laravel 迁移中创建自引用关系(外键)?

在迁移 laravel 5.2 中创建数据库视图