PHP无法间歇性地分配对象参数值

时间:2013-09-09 05:13:56

标签: php object

由于某些原因,PHP无法间歇地为我的对象的属性赋值!如果我不断刷新页面,那么它的工作量大约是5次,但是在失败的那个上,所有的值都没有分配,我发现缺少对象值。

我有一个收集数据库行并将其分配给对象的函数。查询不是每次都要提取数据的问题。问题与这一行有关

$obj->$key = str_replace("''","'",$row[$value[0]]);

我打印输出以确保值存在,然后直接打印出对象参数,我可以看到所有属性值都是空白的。如果我只是将值设置为硬编码字符串,则不会与值本身无关

$obj->$key = 'a'

我对标准变量没有这个问题,值总是在那里,似乎对象参数值不能分配1次超时5.

它似乎不是与代码相关的问题,因为它的工作时间为5次。

function getRow($class,$where = false,$order = false, $limit = false) {

    $obj = new $class();

    $sql = "select * from ".$obj->table." where 1 ";

    if ($where) {
        foreach ($where as $key => $value) {
            $opvalue = $this->getOperator($value);
            $op = $opvalue[0];
            $value = $opvalue[1];
            if ($obj->cols[$key][1] == 1)
            $sql .= "and ".$obj->cols[$key][0]." $op $value ";
            else if ($obj->cols[$key][1] == 2)
            $sql .= "and ".$obj->cols[$key][0]." $op '$value' ";
        }
    }
    if ($order)
    $sql .= "order by $order ";
    if ($limit)
    $sql .= "limit $limit ";

    $res = $this->runQuery($sql);


    //map values
    if ($row = mysql_fetch_assoc($res)) {


//            print_r($row);

        foreach ($obj->cols as $key => $value) {

            if ($obj->cols[$key][1] == 3) {

                $obj->$key = poststringToArray($row[$value[0]]);

            }
            else {

                $obj->$key = str_replace("''","'",$row[$value[0]]);


//                    echo "obj->$key  = {$row[$value[0]]}<br>";
//
//                    echo "obj->$key = ".$obj->$key.'<br>';



            }

        }
//            echo '<p>';
//            print_r($obj);
//            echo '</p>';

    }
    else {

        return false;

    }




    return $obj;
}

忘记上面的复杂代码这是一个简单的例子,其中属性值将间歇性地丢失,但变量保留该值。如果我继续刷新此脚本,“id”的值有时会为空白!

Class SalesOrderService {

var $id;

}
$test = 'a string';

echo 'the value of $test is \''.$test."'";

echo '<p>&nbsp;</p>';

$so = new SalesOrderService();

$so->id = 'aaa';

print_r($so);

1 个答案:

答案 0 :(得分:0)

解决方案是5.3中的一个错误我升级到5.4并且它现在正常工作