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:
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.
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.
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.
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.
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:
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!