Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Bagaimana cara menggunakan Koneksi Persisten dari PDO?

Pertanyaan ini sudah sangat lama tetapi tidak apa-apa jika saya berkontribusi. Saya pikir Anda perlu mengimplementasikan kelas tunggal untuk menangani koneksi database. Saya akan menulis kelas contoh di bawah ini ..

<?php
class DB{

//set the connection property to private to prevent direct access 
private static $conn;

//now since we dont want to reinstiate the class anytime we need it, lets also set the constructor to private 
private function __construct(){}

//now lets create our method for connecting to the database 
public static function connect(){

//now lets check if a connection exists already in our $conn property, then we should return it instead of recreating a new connection 
if(!empty(self::$conn)){
return self::$conn;
}//end if 

//upon reaching here means the $conn property is empty so lets create a new connection 

try {
 $dbh = new PDO('mysql:host=127.0.0.1;dbname=lingtong', 'root', 'xxxxxx', array(PDO::ATTR_PERSISTENT => true));

//lets now assign the database connection to our $conn property 
self::$conn = $dbh;

//return the connection 
return $dbh;

} catch (PDOException $e) {
 print "Error! : " . $e->getMessage() . "<br/>";
 die();
}

}//end method 

}//end class

?>

Kelas tunggal kami hanya dapat membuat satu koneksi dan menggunakannya kembali, mari kita lihat bagaimana kami dapat menggunakan kelas kami

<?php 
$dbh = DB::connect();

foreach ($dbh->query('SELECT * from agent') as $row){ 
  print_r($row);
}
?>


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. sesi php vs kecepatan mysql

  2. Pertanyaan kinerja:ON DUPLICATE KEY UPDATE vs UPDATE (MySQL)

  3. Menggunakan Mongodb dan Mysql dalam satu proyek

  4. mysql - kembalikan kolom pertama sekali dan semua data kolom yang sesuai

  5. tabel WIDE mysql