dongye1912 2016-11-25 10:28
浏览 60
已采纳

PHP重新加载数组值的变量

I'm having a little issue with a variable declaration and value inside an array value. Let me explain:

The situation: I have a 'Require' at the top of my script. Inside this require, there is an array with this content:

....    
$oModules[5]['QUERY'] = array(
    'UPDATE voorraad INNER JOIN import_soldenperc ON import_soldenperc.barbodykleur = voorraad.barbodykleur '.(($trigger_filter_store) ? 'AND import_soldenperc.store = voorraad.mag' : '' ) SET voorraad.solden_pct = import_soldenperc.solden_pct, voorraad.solden_vp = 0, voorraad.solden_sta = DATE(import_soldenperc.solden_sta), voorraad.solden_end = DATE(import_soldenperc.solden_end);'
);
....

As you can see, there is a Variable 'trigger' inside this array value.

The issue: This variable gets set after my require

    ...
    require_once 'application.php';
    ....
    ....
    foreach($headValue..
       if('store' == $fieldValue){
          $trigger_filter_store = true;
       }
    ...

Then at the bottom of my script, there is a function that calls my array value:

foreach ($oModules[$_SESSION['module_id']]['QUERY'] as $Query){
    //Execute query

The problem: My $trigger_filter_store variable gets set at the start, together with the require (which parses the array value to a concated string).

How can I "reload" or "reset" this [QUERY] string with the updated $trigger_filter_store ?

This is a running script where I can't add a lot of changes, because it's a import page that executes the necessary queries, depending on which module is selected in the application.php module-array and I don't want to "break" the entire array-setup.

The only "simple" solution I thought of, was to require my application.php after the variable has been set, but I use some functions from the application.php before I set my variable.

I'm out of ideas really (without breaking the entire script).

Thanks!

  • 写回答

2条回答 默认 最新

  • douwen9540 2016-11-25 10:41
    关注

    You can either use @khuderm solution and use that require after setting the variable, or you can do this:

    $oModules[5]['QUERY'] = array(
        function($trigger_filter_store) {
            return 'UPDATE voorraad INNER JOIN import_soldenperc...';
        }
    )
    

    and then call the function with $Query($trigger_filter_store); in your foreach.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化