doutuo7609 2011-06-14 11:44
浏览 28
已采纳

当我尝试运行它时,PDO类无法返回空白页面?

I've created an email class that will add users to a mysql database. then I've created two methods, the first is private static so I can access it within the second method which is public static, when run this class displays a blank page? What could be the cause of the blank page?

class Email {
private static function DATABASE() {
    $dbh = new PDO("mysql:host=localhost;dbname=emails", 'bjw123nasd4441', 'hj12j2kJKj11s');
    return $dbh;
}
public static function addemail($email) {
    $sqldata = array('email' => $email);
        $stat = Email::DATABASE();
    $stat->prepare("INSERT INTO tasklist (email) VALUES (:email)");
    $stat->execute($sqldata);
    }
}

Email::addemail('foo@bar.com');

I get this error with PHP Display Errors..

Call to undefined method PDO::execute()

  • 写回答

2条回答 默认 最新

  • duanpang2751 2011-06-14 11:53
    关注

    you try to directly call pdo->execute(), that won't work. try this:

    $stat = self::DATABASE();
    $query = $stat->prepare("INSERT INTO tasklist (email) VALUES (:email)");
    $query->execute($sqldata);
    

    and you should also just use one pdo instance:

    class Email {
    
        private static $dbh = null;
    
        private static function DATABASE() {
            if(is_null(self::$dbh))
                self::$dbh = new PDO("mysql:host=localhost;dbname=emails", 'bjw123nasd4441', 'hj12j2kJKj11s');
            return self::$dbh;
        }
    
        //...
    
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?