Rumah >pembangunan bahagian belakang >masalah PHP >Bagaimana untuk menanyakan data melalui pangkalan data dalam php

Bagaimana untuk menanyakan data melalui pangkalan data dalam php

PHPz
PHPzasal
2023-04-12 09:17:271654semak imbas

Dengan perkembangan pesat Internet, PHP ialah bahasa yang ringkas dan mudah dipelajari Semakin ramai orang mula belajar dan menggunakan PHP. Salah satu aplikasi utama ialah menanyakan pangkalan data melalui pangkalan data. Artikel ini akan memperkenalkan secara terperinci cara menggunakan PHP untuk pertanyaan pangkalan data, serta beberapa petua praktikal dan amalan terbaik.

1. Pengenalan kepada pangkalan data

Pangkalan data ialah sistem penyimpanan dan pengurusan data dalam sistem komputer. Mereka boleh menyimpan data dalam jadual dan menggunakan pelbagai algoritma dan struktur data untuk meningkatkan kelajuan dan kecekapan akses data. Dalam aplikasi sebenar, pangkalan data hubungan adalah pangkalan data yang paling biasa digunakan. Sebagai contoh, MySQL ialah pangkalan data hubungan yang biasa digunakan yang digunakan secara meluas dalam pembangunan web.

2. Sambung ke pangkalan data

PHP menyediakan banyak fungsi untuk menyambung ke pelbagai jenis pangkalan data. Di bawah ini kami mengambil MySQL sebagai contoh untuk memperkenalkan cara menyambung ke pangkalan data.

Sebelum menyambung ke pangkalan data MySQL, anda perlu memasang MySQL dan mendapatkan maklumat berikut:

  • Nama hos
  • Nombor akaun
  • Kata Laluan
  • Nama pangkalan data

Berikut ialah kod PHP yang digunakan untuk menyambung ke pangkalan data MySQL:

$host = 'localhost';
$user = 'root';
$password = 'yourPassword';
$dbname = 'yourDatabaseName';

// 建立连接
$conn = mysqli_connect($host, $user, $password, $dbname);

// 检查连接是否成功
if (!$conn) {
    die('连接失败: ' . mysqli_connect_error());
}
echo "连接成功";

Kod di atas akan menyambung ke pangkalan data MySQL yang ditentukan dan lakukan beberapa pengendalian Ralat yang mudah.

3. Tanya pangkalan data

Selepas menyambung ke pangkalan data MySQL, anda boleh menggunakan fungsi PHP untuk membuat pertanyaan dan mengemas kini pangkalan data. Berikut ialah contoh asas pertanyaan data melalui pernyataan SELECT:

$sql = "SELECT * FROM users"; // 查询所有用户
$result = mysqli_query($conn, $sql);

// 迭代输出结果
if (mysqli_num_rows($result) > 0) {
    while($row = mysqli_fetch_assoc($result)) {
        echo "ID: " . $row["id"]. " - Name: " . $row["name"]. " - Email: " . $row["email"] . "<br>";
    }
} else {
    echo "未找到任何记录";
}

Kod di atas akan mendapatkan semula semua data daripada jadual pengguna dan mengulangi setiap baris hasil dan mengeluarkannya ke halaman. Fungsi mysqli_fetch_assoc() menukar hasil pertanyaan kepada tatasusunan bersekutu.

4. Masukkan dan kemas kini data

Setelah disambungkan ke pangkalan data MySQL, anda boleh memasukkan dan mengemas kini data. Berikut ialah contoh melaksanakan pernyataan INSERT dan UPDATE:

// 插入数据
$sql = "INSERT INTO users (name, email) VALUES ('John Doe', 'john@example.com')";
if (mysqli_query($conn, $sql)) {
    echo "新记录插入成功";
} else {
    echo "插入记录时发生错误: " . mysqli_error($conn);
}

// 更新数据
$sql = "UPDATE users SET email='newemail@example.com' WHERE id=2";
if (mysqli_query($conn, $sql)) {
    echo "记录更新成功";
} else {
    echo "更新记录时发生错误: " . mysqli_error($conn);
}

Kod di atas akan memasukkan rekod baharu ke dalam jadual pengguna dan kemudian mengemas kini alamat e-mel rekod dengan id 2.

5. Tutup sambungan pangkalan data

Apabila anda selesai mengendalikan pangkalan data, anda perlu menutup sambungan pangkalan data. Berikut ialah contoh menutup sambungan pangkalan data MySQL:

mysqli_close($conn);

6. Ralat mengendalikan amalan terbaik

Dalam aplikasi praktikal, pengendalian ralat adalah sangat penting kerana ia melindungi pangkalan data anda daripada Serangan dan pepijat. Berikut ialah beberapa amalan terbaik pengendalian ralat:

  1. Gunakan pernyataan cuba-tangkap untuk menangkap ralat pangkalan data.
// try-catch捕获数据库错误
try {
    $sql = "SELECT * FROM users WHERE id = 1";
    $result = mysqli_query($conn, $sql);
    if (!$result) {
        throw new Exception(mysqli_error($conn));
    }
} catch (Exception $e) {
    echo "无法检索数据:" . $e->getMessage();
}
  1. Gunakan pernyataan yang disediakan untuk mengelakkan serangan suntikan SQL.
// 预处理语句预防SQL注入攻击
$stmt = mysqli_prepare($conn, "SELECT * FROM users WHERE username=?");
mysqli_stmt_bind_param($stmt, 's', $username);
mysqli_stmt_execute($stmt);

7 Kesimpulan

PHP ialah bahasa yang berkuasa dan mudah dipelajari, serta mempunyai pelbagai aplikasi dalam pertanyaan pangkalan data dan kemas kini. Digunakan dalam kombinasi dengan pangkalan data hubungan seperti MySQL, PHP boleh membantu pembangun mengakses dan mengurus maklumat pangkalan data dengan berkesan. Melalui pengenalan dan contoh artikel ini, anda seharusnya mempunyai pemahaman tertentu tentang cara menyambung dan menanyakan pangkalan data MySQL. Pada masa yang sama, kami juga menyediakan beberapa petua praktikal dan amalan terbaik supaya anda boleh menggunakan PHP dengan lebih baik untuk memproses maklumat pangkalan data.

Atas ialah kandungan terperinci Bagaimana untuk menanyakan data melalui pangkalan data dalam php. 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