cari
Rumahpembangunan bahagian belakangtutorial php在构造方法中使用静态属性保留的PDO资源句柄在其他方法中无法调用?

在构造方法中使用静态属性保存的PDO资源句柄在其他方法中无法调用???

<?php<br /><br />class DB{<br />    protected $link = '127.0.0.1';<br />    protected $dbname = 'think';<br />    static public $DB;<br />    private function __construct(){<br />        try{<br />            self::$DB = new PDO("mysql:host={$this->link};dbname={$this->dbname}",'root','root');<br />        }catch (PDOException $e){<br />            die("连接出错:".$e->getMessage());<br />        }<br /><br />        $sql = ' SELECT * FROM user WHERE id=? and username=? and email=? ';<br />        $stmt = self::$DB->prepare($sql);<br />        $stmt->execute([0=>'13',1=>'12',2=>'12']);<br />        echo '<pre class="brush:php;toolbar:false">';<br />        print_r($stmt->fetchAll(PDO::FETCH_ASSOC));<br />        echo $stmt->rowCount();<br />    }<br />    //静态方法,单例统一访问入口<br />    static public function getInstance() {<br />        if (is_null ( self::$DB ) || isset ( self::$DB )) {<br />            self::$DB = new self ();<br />        }<br />        return self::$DB;<br />    }<br />    public function Test(){<br />         $sql = ' SELECT * FROM user WHERE id=? and username=? and email=? ';<br />         $stmt = self::$DB->prepare($sql);<br />         $stmt->execute([0=>'13',1=>'12',2=>'12']);<br />         echo '<pre class="brush:php;toolbar:false">';<br />         print_r($stmt->fetchAll(PDO::FETCH_ASSOC));<br />         echo $stmt->rowCount();<br />    }<br />}<br />$db = DB::getInstance();<br />$db->Test();

我把Test方法复制在构造方法没有问题,为什么在Test方法中会出现Call to undefined method DB::prepare()???
求各位大神了
------解决思路----------------------
你至少应写作
class DB{<br />    protected $link = '127.0.0.1';<br />    protected $dbname = 'think';<br />    static public $DB;<br />    static public $_DB;<br />    private function __construct(){<br />        try{<br />            self::$_DB = new PDO("mysql:host={$this->link};dbname={$this->dbname}",'root','root');<br />        }catch (PDOException $e){<br />            die("连接出错:".$e->getMessage());<br />        }<br />    }<br />    //静态方法,单例统一访问入口<br />    static public function getInstance() {<br />        if (is_null ( self::$DB ) <br><font color='#FF8000'>------解决思路----------------------</font><br> isset ( self::$DB )) {<br />            self::$DB = new self ();<br />        }<br />        return self::$DB;<br />    }<br />    public function Test(){<br />         $sql = ' SELECT * FROM user WHERE id=? and username=? and email=? ';<br />         $stmt = self::$_DB->prepare($sql);<br />         $stmt->execute([0=>'13',1=>'12',2=>'12']);<br />         echo '<pre class="brush:php;toolbar:false">';<br />         print_r($stmt->fetchAll(PDO::FETCH_ASSOC));<br />         echo $stmt->rowCount();<br />    }<br />}<br />$db = DB::getInstance();<br />$db->Test();
PDO 本身已经封装的很好了,如确需要进一步封装以简化调用代码
那么应该从 PDO 继承一个 DB 类,如
class DB extends PDO {<br />  private static $_Instance;<br />  function __construct() {<br />	$options = array(<br />		PDO::MYSQL_ATTR_INIT_COMMAND => "set names gbk",<br />		PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,<br />		PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,<br />		);<br /><br />    parent::__construct('mysql:dbname=test', 'root', '', $options);<br />  }<br />  //执行各种 sql 指令,并可通过参数 $param 进行扩展<br />  function query($sql, $param=null) {<br />	$res = [];<br />	try {<br />		$rs = parent::query($sql);<br />		do {<br />			if($t = $rs->fetchall()) $res[] = $t;<br />		}while($rs->nextRowset());<br />		return $res;<br />	} catch (PDOException $e) {<br />		die( "Error!: " . $e->getMessage() . "\n" );<br />		//  die();<br />	}<br />  }<br />  //查询并返回单条记录<br />  static function fetch($sql) {<br />	if(! self::$_Instance) self::$_Instance = new self;<br />	return self::$_Instance->query($sql)[0][0];//->fetch();<br />  }<br />  //查询并以数组方式返回多条记录<br />  static function fetchall($sql) {<br />	if(! self::$_Instance) self::$_Instance = new self;<br />	$res = self::$_Instance->query($sql);//->fetchall();<br />	if(count($res) == 1) return current($res);<br />  }<br />}<br />
这样你就有机会这样使用了
$r = DB::fetch("select * from user where name='my'");

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Apakah kaedah terbaik untuk menghantar e -mel menggunakan php?Apakah kaedah terbaik untuk menghantar e -mel menggunakan php?May 08, 2025 am 12:21 AM

Thebestapproachforsendingemailsinphpisusingthephpmaillibraryduetoitsreliability, featureRichness, andeaseofuse.phpmailersupportssmtp, proveddetaileDerrorHandling, membolehkanSendsendingHtmlandPlainteMails, supportsattachments, danStoVeShanCess

Amalan terbaik untuk suntikan ketergantungan dalam phpAmalan terbaik untuk suntikan ketergantungan dalam phpMay 08, 2025 am 12:21 AM

Alasan untuk menggunakan suntikan ketergantungan (DI) ialah ia menggalakkan gandingan longgar, kebolehlihatan, dan pemeliharaan kod. 1) Gunakan pembina untuk menyuntik kebergantungan, 2) Elakkan menggunakan pencari perkhidmatan, 3) Gunakan bekas suntikan ketergantungan untuk menguruskan kebergantungan, 4) meningkatkan kesesuaian melalui suntikan suntikan, 5) Elakkan kebergantungan over-suntikan, 6) Pertimbangkan kesan DI terhadap prestasi.

Petua Penalaan Prestasi PHPPetua Penalaan Prestasi PHPMay 08, 2025 am 12:20 AM

Phpperformancetuningiscrucialbecauseitenhancesspeedandeficiency, whoarevitalforwebapplications.1) cachingwithapcureSdatabaseloadandimprovesresponsetimes.2)

Keselamatan e -mel PHP: Amalan terbaik untuk menghantar e -melKeselamatan e -mel PHP: Amalan terbaik untuk menghantar e -melMay 08, 2025 am 12:16 AM

TthebestpracticesforDailssecureeleynpinceDudududude: 1) usingSecureConfigurationsatiationswithsmtpandStartTartTlSencrryption, 2) vactrentatiatingIsTitionputStopReventInJectaCtAtactaSs, 3) engrypTyptingSensensitiVIdAdAlsHAlSiSsSenSsensSl ,SsengsSenSsensSl ,SsengSiSsSSSsSsSsSsSsSsSsSsSsSsSsSsSsSsSsSsSsSsSsSssSsSsSsSsSsSsSsSsSsSsSsSsSsSsSsSSSSsSSSSSSSSSHAsSsSSSSSHAsSsSengs.)

Bagaimana anda mengoptimumkan aplikasi PHP untuk prestasi?Bagaimana anda mengoptimumkan aplikasi PHP untuk prestasi?May 08, 2025 am 12:08 AM

TooptimizePHPapplicationsforperformance,usecaching,databaseoptimization,opcodecaching,andserverconfiguration.1)ImplementcachingwithAPCutoreducedatafetchtimes.2)Optimizedatabasesbyindexing,balancingreadandwriteoperations.3)EnableOPcachetoavoidrecompil

Apakah suntikan ketergantungan dalam php?Apakah suntikan ketergantungan dalam php?May 07, 2025 pm 03:09 PM

DependencyInjectionPhpisadesignPatternThatenhancesflexibility, Testability, andMaintainabilitybyprovidingExternalDependencyestoclasses.Illowsforloosecoupling, easiertestingthroughmocking, andmodulardesignesign, ButrequirescareFareFingStructures-Inje

Teknik Pengoptimuman Prestasi PHP TerbaikTeknik Pengoptimuman Prestasi PHP TerbaikMay 07, 2025 pm 03:05 PM

Pengoptimuman prestasi PHP boleh dicapai melalui langkah -langkah berikut: 1) Gunakan memerlukan_once atau termasuk_once di bahagian atas skrip untuk mengurangkan bilangan beban fail; 2) Gunakan penyataan preprocessing dan pemprosesan batch untuk mengurangkan bilangan pertanyaan pangkalan data; 3) Konfigurasikan opcache untuk cache opcode; 4) membolehkan dan mengkonfigurasi pengurusan proses pengoptimuman PHP-FPM; 5) Gunakan CDN untuk mengedarkan sumber statik; 6) Gunakan XDEBUG atau Blackfire untuk analisis prestasi kod; 7) Pilih struktur data yang cekap seperti tatasusunan; 8) Tulis kod modular untuk pelaksanaan pengoptimuman.

Pengoptimuman Prestasi PHP: Menggunakan Caching OpcodePengoptimuman Prestasi PHP: Menggunakan Caching OpcodeMay 07, 2025 pm 02:49 PM

OpcodecachingsignificelymprovesphperformanceCachingCompiledCode, reducingservervoadandresponsetimes.1) itstorescompiledphpcodeinmemory, bypassingparsingandcompiling.2)

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.