首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >函数调用有什么问题?

函数调用有什么问题?
EN

Stack Overflow用户
提问于 2016-06-17 23:54:44
回答 1查看 72关注 0票数 0

我有2个php文件(function.php,dp.php)在dp.php中,我调用update函数如下

代码语言:javascript
复制
include('function.php');
$db = new Database();
$db->connect();
$db->update('classes', array('level'=> '(CASE WHEN level = 1 THEN 2
                WHEN level = 2 THEN 3
                WHEN level = 3 THEN 4                    
                END)','modifiedTime'=>date("Y-m-d H:i:s")), 'level IN (1,2,3)');
$res = $db->getResult();
print_r($res);

和更新功能:

代码语言:javascript
复制
     public function update($table,$params=array(),$where){
    if($this->tableExists($table)){
        $args=array();
        foreach($params as $field=>$value){
            $args[]=$field.'="'.$value.'"';
        }
        $sql='UPDATE '.$table.' SET '.implode(',',$args).' WHERE '.$where;          
        $this->myQuery = $sql; // Pass back the SQL
        if($query = $this->myconn->query($sql)){
            array_push($this->result,$this->myconn->affected_rows);
            return true; 
        }else{
            array_push($this->result,$this->myconn->error);
            return false;
        }
    }else{
        return false;
    }
}

我总是得到的结果是0,其中应该是2,3,或4。

在执行phpmyadmin时,is工作的实际语句是:

代码语言:javascript
复制
    update classes set level = (CASE WHEN level = 1 THEN 2
                WHEN level = 2 THEN 3
                WHEN level = 3 THEN 4                    
                END), modifiedTime = date("Y-m-d H:i:s")) WHERE level IN (1,2,3));

提前感谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-06-18 01:27:23

您可以尝试使用current_timestamp而不是使用日期(..)在你的db.php里

代码语言:javascript
复制
    include('function.php');
    $db = new Database();
     $db->connect();
     $db->update('tbl_class', array('level'=> '(CASE WHEN level = 1 THEN 2
                WHEN level = 2 THEN 3
                WHEN level = 3 THEN 4                    
                END)','update_time' => CURRENT_TIMESTAMP), 'level IN (1,2,3)');
     $res = $db->getResult();
     print_r($res);

还有一件事要做,就是纠正你的函数。

代码语言:javascript
复制
        public function update($table,$params=array(),$where){
        if($this->tableExists($table)){
        $args=array();
        foreach($params as $field=>$value){
            $args[]=$field.' = '.$value.' ';
        }
        $sql='UPDATE '.$table.' SET '.implode(' , ',$args).' WHERE '.$where;
        $this->myQuery = $sql; 
        if($query = $this->myconn->query($sql)){
            array_push($this->result,$this->myconn->affected_rows);
            return true; 
        }else{
            array_push($this->result,$this->myconn->error);
            return false; 
        }
    }else{
        return false; 
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37891913

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档