Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/loops/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
函数中循环内的php变量范围_Php_Loops_Variables_Scope - Fatal编程技术网

函数中循环内的php变量范围

函数中循环内的php变量范围,php,loops,variables,scope,Php,Loops,Variables,Scope,我想知道有没有办法得到一个变量的值,这个变量是在函数内部的循环中定义的 循环/if-then-else等中声明的变量的作用域是否有限(仅在这些块内) 下面是一个函数示例: <?php function getComments($tabName) { $sql = "select a.owner, a.table_name, a.column_name, a.data_type, a.d

我想知道有没有办法得到一个变量的值,这个变量是在函数内部的循环中定义的

循环/if-then-else等中声明的变量的作用域是否有限(仅在这些块内)

下面是一个函数示例:

<?php

function getComments($tabName) {
    $sql = "select
                a.owner,
        a.table_name,
        a.column_name,
        a.data_type,
        a.data_length,
        a.data_precision,
        b.comments
            from 
                all_tab_columns a,
        user_col_comments b
            where 
                a.TABLE_NAME = b.table_name
        and a.COLUMN_NAME = b.column_name
        and a.owner = 'CORE' 
        and a.table_name ='" . $tabName . "'
            order by 
                a.column_id";
    $stid = oci_parse(getConnect(), $sql);

    // runs the query above                   
    oci_execute($stid);
    while ($row = oci_fetch_array($stid, OCI_ASSOC + OCI_RETURN_NULLS)) {
        foreach ($row as $column => $entry) {
            // Column name
            if ($column == 'COLUMN_NAME') {
                $output = "this is a column";
            }
        }
    }

    return $output;
}

尝试满足此条件

        if ($column == 'COLUMN_NAME') {
            $output = "this is a column";
        }
        if ($column == 'COLUMN_NAME') {
            return "this is a column";
        }
你也可以在病情好转后立即返回

        if ($column == 'COLUMN_NAME') {
            $output = "this is a column";
        }
        if ($column == 'COLUMN_NAME') {
            return "this is a column";
        }

似乎未设置
$output
变量,因为未满足if条件。您应该从
$output=''开始位于函数顶部以避免此问题。感谢您的提示。但是,当我在开始尝试$output=”“时,我只在输出中得到一个空结果。它与@ʰ保持不变ᵈˑ建议使用
$output.='这是一列',您仍然应该检查if语句,因为它显然没有得到满足。您需要弄清楚为什么没有发生这种情况。也许可以更改保存循环结果的方式,也许可以将其保存到数组中。这样你就可以看到你实际返回的内容。注释掉“if”行并使
$output
成为一个数组。这会将所有变量发送到一个数组中进行求值。您仍然忽略了if语句返回true的明显问题。。。或者,从
while
foreach
循环中,由于SQL结果为空,可能从未实际执行。如果我在条件之后立即返回,它将显示空结果。它似乎只在if/then/else和循环块之外返回。这是我的sql连接/语句逻辑中的一个错误,因为我在获取数据时得到了“false”。