Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana PHP menggunakan PDO untuk mengendalikan pangkalan data

Bagaimana PHP menggunakan PDO untuk mengendalikan pangkalan data

王林
王林asal
2023-06-18 08:36:131590semak imbas

Dalam pembangunan web, pangkalan data adalah komponen yang sangat penting. Seperti bahasa pengaturcaraan lain, bahasa PHP juga mempunyai banyak cara untuk mengendalikan pangkalan data. Antaranya, PDO (Objek Data PHP) adalah salah satu cara biasa untuk mengendalikan pangkalan data dalam PHP Ia menyediakan kaedah bersatu, mudah, fleksibel dan selamat untuk mengakses sistem pangkalan data yang berbeza. Artikel ini akan memperkenalkan cara PHP menggunakan PDO untuk mengendalikan pangkalan data.

1. Kelebihan PDO

Kelebihan menggunakan PDO untuk mengendalikan pangkalan data adalah seperti berikut:

  1. Program ini sangat mudah alih: menggunakan PDO untuk mengendalikan pangkalan data lebih mudah alih ia kukuh dan boleh dijalankan pada pangkalan data yang berbeza tanpa memerlukan perubahan besar pada program.
  2. Keselamatan tinggi: PDO menyokong pemprosesan parameter baris arahan, yang boleh menghalang serangan suntikan SQL dengan berkesan.
  3. Berorientasikan objek: PDO berorientasikan objek dan boleh menjadikan pengaturcaraan OOP lebih mudah.
  4. Prestasi yang baik: PDO menyokong penyataan yang disediakan dan pengikatan data, yang boleh meningkatkan kecekapan pertanyaan dengan sangat baik dan dengan itu meningkatkan prestasi program.

2. Gunakan PDO untuk menyambung ke pangkalan data

Sebelum anda mula menggunakan PDO untuk mengendalikan pangkalan data, anda perlu menyambung ke pangkalan data terlebih dahulu. Kod untuk menyambung ke pangkalan data adalah seperti berikut:

//设置数据库连接信息
$dsn = 'mysql:host=localhost;dbname=testdb';
$username = 'root';
$password = 'root';
$options = [
    //错误模式:在发生错误时抛出异常
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
    //默认返回关联数组
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC
];
//创建PDO对象
$pdo = new PDO($dsn, $username, $password, $options);

Antaranya, $dsn mewakili jenis pangkalan data, nama hos, nama pangkalan data dan maklumat lain, $nama pengguna mewakili nama pengguna, $kata laluan mewakili kata laluan, $options mewakili tetapan, seperti menetapkan mod ralat, Jenis data kembali, dsb. Apabila menyambung ke pangkalan data, anda juga boleh menetapkan pilihan lain, seperti:

$options = [
    //设置字符集
    PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8',
    //关闭持久连接
    PDO::ATTR_PERSISTENT => false,
    //设置超时时间
    PDO::ATTR_TIMEOUT => 10,
    //设置返回数据类型为对象
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_OBJ,
    // 禁用预处理语句的模拟
    PDO::ATTR_EMULATE_PREPARES => false,
];

3. PDO melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan

Selepas menyambung ke pangkalan data, anda boleh melakukan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pada pangkalan data. Operasi yang biasa digunakan termasuk: memasukkan data, mengemas kini data, memadam data dan menyoal data.

  1. Sisipkan data

Kod untuk menggunakan PDO untuk memasukkan data ke dalam pangkalan data adalah seperti berikut:

//插入数据
$sql = "INSERT INTO `users` (`name`,`age`,`email`) VALUES (:name,:age,:email)";
$name = 'Tom';
$age = 23;
$email = 'tom@example.com';
$stmt = $pdo->prepare($sql);
$stmt->bindValue(':name', $name);
$stmt->bindValue(':age', $age);
$stmt->bindValue(':email', $email);
$stmt->execute();

Di mana, $sql ialah pernyataan SQL untuk memasukkan data, gunakan Kaedah pengikatan parameter boleh mengelakkan serangan suntikan SQL. Kaedah bindValue() akan mengikat parameter kepada pemegang tempat dengan nama yang ditentukan, dan kemudian memanggil kaedah execute() untuk menyerahkan pertanyaan kepada pangkalan data.

  1. Kemas kini data

Kod untuk mengemas kini data menggunakan PDO adalah seperti berikut:

//更新数据
$sql = "UPDATE `users` SET `age` = :age WHERE `name` = :name";
$name = 'Tom';
$age = 24;
$stmt = $pdo->prepare($sql);
$stmt->bindValue(':name', $name);
$stmt->bindValue(':age', $age);
$stmt->execute();

Antaranya, $sql ialah pernyataan SQL untuk mengemas kini data, menggunakan pengikatan parameter Dalam cara tertentu, serangan suntikan SQL boleh dielakkan. Kaedah bindValue() akan mengikat parameter kepada pemegang tempat dengan nama yang ditentukan, dan kemudian memanggil kaedah execute() untuk menyerahkan pertanyaan kepada pangkalan data.

  1. Padam data

Kod untuk memadam data menggunakan PDO adalah seperti berikut:

//删除数据
$sql = "DELETE FROM `users` WHERE `name` = :name";
$name = 'Tom';
$stmt = $pdo->prepare($sql);
$stmt->bindValue(':name', $name);
$stmt->execute()

Antaranya, $sql ialah pernyataan SQL untuk memadam data , menggunakan pengikatan parameter Dalam cara tertentu, serangan suntikan SQL boleh dielakkan. Kaedah bindValue() akan mengikat parameter kepada pemegang tempat dengan nama yang ditentukan, dan kemudian memanggil kaedah execute() untuk menyerahkan pertanyaan kepada pangkalan data.

  1. Data pertanyaan

Kod untuk pertanyaan data menggunakan PDO adalah seperti berikut:

//查询数据
$sql = "SELECT * FROM `users` WHERE `age` > :age";
$age = 20;
$stmt = $pdo->prepare($sql);
$stmt->bindValue(':age', $age);
$stmt->execute();
$rows = $stmt->fetchAll();

Antaranya, $sql ialah pernyataan SQL untuk pertanyaan data , menggunakan pengikatan parameter Dalam cara tertentu, serangan suntikan SQL boleh dielakkan. Kaedah bindValue() akan mengikat parameter kepada pemegang tempat dengan nama yang ditentukan, dan kemudian memanggil kaedah execute() untuk menyerahkan pertanyaan kepada pangkalan data. Kaedah fetchAll() mengembalikan hasil pertanyaan sebagai tatasusunan berbilang dimensi.

Memandangkan PDO menyokong mendapatkan hasil daripada tiga jenis: tatasusunan bersekutu, tatasusunan angka dan objek, apabila menanyakan keputusan, anda perlu menetapkan jenis pemerolehan pengambilan, contohnya:

//查询并获取关联数组
$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);
 
//查询并获取数字数组
$rows = $stmt->fetchAll(PDO::FETCH_NUM);
 
//查询并获取对象数组
$rows = $stmt->fetchAll(PDO::FETCH_OBJ);

4. Pelaksanaan PDO Pemprosesan transaksi

PDO menyokong pemprosesan transaksi dan anda boleh menggunakan kaedah beginTransaction(), commit() dan rollback() untuk melaksanakan operasi penyerahan transaksi dan rollback.

try {
    //开启事务
    $pdo->beginTransaction();
    //执行增删改操作语句
    $pdo->exec($sql1);
    $pdo->exec($sql2);
    $pdo->exec($sql3);
    //提交事务
    $pdo->commit();
} catch (Exception $e) {
    //回滚事务
    $pdo->rollback();
}

Di atas adalah pengenalan asas untuk menggunakan PDO untuk mengendalikan pangkalan data Terdapat beberapa perkara yang perlu diberi perhatian semasa mengendalikan pangkalan data dengan PDO:

  1. Menggunakan parameter. mengikat boleh mengelakkan serangan suntikan SQL.
  2. Tetapkan mod ralat pengecualian PDO kepada EXCEPTION untuk menangkap pengecualian dengan mudah.
  3. Menggunakan kaedah prepare() untuk melaksanakan penyataan operasi boleh cache set hasil untuk meningkatkan kecekapan pertanyaan.
  4. Penyata prapemprosesan dan pengikatan data boleh mengelakkan kerja berulang untuk menganalisis dan mengoptimumkan kenyataan, mencapai kecekapan pertanyaan yang lebih tinggi.
  5. Mendayakan pemprosesan transaksi boleh memastikan integriti dan konsistensi data.

Ringkasnya, menggunakan PDO untuk mengendalikan pangkalan data adalah cara yang agak mudah dan berkesan, yang boleh menyediakan keupayaan capaian pangkalan data yang berkuasa untuk aplikasi web.

Atas ialah kandungan terperinci Bagaimana PHP menggunakan PDO untuk mengendalikan pangkalan data. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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