时间:2021-07-01 10:21:17 帮助过:15人阅读
- <!--?phpclass DB{ protected $link = '127.0.0.1'; protected $dbname = 'think'; static public $DB; private function __construct(){ try{ self::$DB = new PDO("mysql:host={$this--->link};dbname={$this->dbname}",'root','root'); }catch (PDOException $e){ die("连接出错:".$e->getMessage()); } $sql = ' SELECT * FROM user WHERE id=? and username=? and email=? '; $stmt = self::$DB->prepare($sql); $stmt->execute([0=>'13',1=>'12',2=>'12']); echo '<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li>'; print_r($stmt->fetchAll(PDO::FETCH_ASSOC)); echo $stmt->rowCount(); } //静态方法,单例统一访问入口 static public function getInstance() { if (is_null ( self::$DB ) || isset ( self::$DB )) { self::$DB = new self (); } return self::$DB; } public function Test(){ $sql = ' SELECT * FROM user WHERE id=? and username=? and email=? '; $stmt = self::$DB->prepare($sql); $stmt->execute([0=>'13',1=>'12',2=>'12']); echo '<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li>'; print_r($stmt->fetchAll(PDO::FETCH_ASSOC)); echo $stmt->rowCount(); }}$db = DB::getInstance();$db->Test();</li></ol></pre> <br> 我把Test方法复制在构造方法没有问题,为什么在Test方法中会出现Call to undefined method DB::prepare()??? <br> 求各位大神了 <p> </p> <p></p> <br> <h2>回复讨论(解决方案)</h2> <p class="sougouAnswer"> </p> <p class="sougouAnswer"> $DB->prepare没有prepare方法,说明$DB可能没有被实例化,在实例化之后打印DB类里吗的$DB变量看看 </p> <p class="sougouAnswer"> 在构造函数中,self::$DB 是 PDO 对象,所以有prepare 方法 <br> <br> 在 getInstance 方法中,你又 self::$DB = new self (); 把 self::$DB 赋值为 DB 对象,所以就没有了 prepare 方法 </p> <p class="sougouAnswer"> 你至少应写作 </p><pre class="sycode layui-box layui-code-view layui-code-notepad" name="code"><ol class="layui-code-ol"><li>class DB{ protected $link = '127.0.0.1'; protected $dbname = 'think'; static public $DB; static public $_DB; private function __construct(){ try{ self::$_DB = new PDO("mysql:host={$this->link};dbname={$this->dbname}",'root','root'); }catch (PDOException $e){ die("连接出错:".$e->getMessage()); } } //静态方法,单例统一访问入口 static public function getInstance() { if (is_null ( self::$DB ) || isset ( self::$DB )) { self::$DB = new self (); } return self::$DB; } public function Test(){ $sql = ' SELECT * FROM user WHERE id=? and username=? and email=? '; $stmt = self::$_DB->prepare($sql); $stmt->execute([0=>'13',1=>'12',2=>'12']); echo '<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li>'; print_r($stmt->fetchAll(PDO::FETCH_ASSOC)); echo $stmt->rowCount(); }}$db = DB::getInstance();$db->Test();</li></ol></pre>PDO 本身已经封装的很好了,如确需要进一步封装以简化调用代码 <br> 那么应该从 PDO 继承一个 DB 类,如 <pre class="sycode layui-box layui-code-view layui-code-notepad" name="code"><ol class="layui-code-ol"><li>class DB extends PDO { private static $_Instance; function __construct() {</li><li>$options = array(</li><li>PDO::MYSQL_ATTR_INIT_COMMAND => "set names gbk",</li><li>PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,</li><li>PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,</li><li>); parent::__construct('mysql:dbname=test', 'root', '', $options); } //执行各种 sql 指令,并可通过参数 $param 进行扩展 function query($sql, $param=null) {</li><li>$res = [];</li><li>try {</li><li>$rs = parent::query($sql);</li><li>do {</li><li>if($t = $rs->fetchall()) $res[] = $t;</li><li>}while($rs->nextRowset());</li><li>return $res;</li><li>} catch (PDOException $e) {</li><li>die( "Error!: " . $e->getMessage() . "\n" );</li><li>// die();</li><li>} } //查询并返回单条记录 static function fetch($sql) {</li><li>if(! self::$_Instance) self::$_Instance = new self;</li><li>return self::$_Instance->query($sql)[0][0];//->fetch(); } //查询并以数组方式返回多条记录 static function fetchall($sql) {</li><li>if(! self::$_Instance) self::$_Instance = new self;</li><li>$res = self::$_Instance->query($sql);//->fetchall();</li><li>if(count($res) == 1) return current($res); }}</li></ol></pre>这样你就有机会这样使用了 <br> $r = DB::fetch("select * from user where name='my'"); <p></p> <p class="sougouAnswer"> </p><pre class="sycode layui-box layui-code-view layui-code-notepad" name="code"><ol class="layui-code-ol"><li> if (!self::$DB instanceof self) { self::$DB = new self (); } return self::$DB;</li></ol></pre> <p></p> <p class="sougouAnswer"> 多谢@xuzuning </p></li></ol></pre></li></ol></pre>