Rumah pembangunan bahagian belakang masalah PHP Bagaimana untuk mengendalikan pangkalan data melalui tetingkap pop timbul PHP

Bagaimana untuk mengendalikan pangkalan data melalui tetingkap pop timbul PHP

Apr 18, 2023 am 09:48 AM

Sebagai pembangun PHP, kami selalunya perlu mengendalikan pangkalan data. Dalam projek sebenar, kita selalunya perlu menggunakan tetingkap timbul untuk melaksanakan beberapa operasi, seperti pemadaman, pengubahsuaian, dsb.

Artikel ini akan memperkenalkan cara mengendalikan pangkalan data melalui tetingkap pop timbul PHP, bertujuan untuk membantu pembaca menguasai kemahiran ini dengan lebih baik.

1. Kerja penyediaan

Sebelum melaksanakan tetingkap timbul, kami perlu menyediakan kerja berikut:

1 sambungan pangkalan data.

2. Pertanyaan pangkalan data: Kami perlu menggunakan PHP untuk menanyakan pangkalan data untuk mendapatkan data yang perlu dikendalikan.

3. Kod tetingkap timbul: Kami perlu menggunakan JavaScript atau jQuery untuk menulis kod tetingkap timbul.

Untuk kemudahan demonstrasi, di sini kami menggunakan MySQL sebagai pangkalan data dan PHP PDO untuk menyambung ke pangkalan data.

2. Padam data

Di bawah ini kami akan memperkenalkan cara memadam data melalui tetingkap timbul. Pertama, kita perlu mendapatkan data untuk dipadamkan daripada pangkalan data dan kemudian memaparkannya pada halaman untuk memudahkan pemilihan pengguna.

1. Data pertanyaan

Kami boleh menggunakan kod berikut untuk menanyakan data yang perlu dipadamkan:

<?php
//连接数据库
$dsn = &#39;mysql:host=localhost;dbname=test;charset=utf8&#39;;
$username = &#39;root&#39;;
$password = &#39;123456&#39;;
$options = [
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, //异常处理模式
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, //默认的查询结果类型
];
$pdo = new PDO($dsn, $username, $password, $options);

//查询要删除的数据
$sql = "SELECT * FROM test_table WHERE status = 0"; //status字段表示待删除数据
$stmt = $pdo->prepare($sql);
$stmt->execute();
$data = $stmt->fetchAll();
?>
Salin selepas log masuk

Dalam kod di atas, kami mula-mula menyambung ke pangkalan data dan pertanyaan menggunakan pernyataan SELECT Data yang perlu dipadamkan. Antaranya, medan status menunjukkan data yang akan dipadamkan.

  1. Paparkan data

Seterusnya, kami memaparkan data yang ditanya pada halaman untuk dipilih oleh pengguna.

<table>
    <thead>
        <tr>
            <th>ID</th>
            <th>Name</th>
            <th>Email</th>
            <th>Action</th>
        </tr>
    </thead>
    <tbody>
        <?php foreach($data as $index=>$row): ?>
        <tr>
            <td><?php echo $row[&#39;id&#39;]; ?></td>
            <td><?php echo $row[&#39;name&#39;]; ?></td>
            <td><?php echo $row[&#39;email&#39;]; ?></td>
            <td><button class="delete-btn" data-id="<?php echo $row[&#39;id&#39;]; ?>">删除</button></td>
        </tr>
        <?php endforeach; ?>
    </tbody>
</table>
Salin selepas log masuk

Dalam kod di atas, kami menggunakan jadual HTML untuk memaparkan data pertanyaan pada halaman. Untuk melaksanakan fungsi padam, kami menambah butang padam pada setiap baris data dan menyimpan nilai ID yang sepadan melalui atribut data-id.

  1. Padam data

Akhir sekali, mari kita laksanakan fungsi pemadaman. Apabila pengguna mengklik butang padam, kami akan muncul kotak pengesahan yang meminta pengguna sama ada untuk memadam data. Jika pengguna mengesahkan pemadaman, kami akan menghantar permintaan AJAX untuk memadam data daripada pangkalan data.

$('.delete-btn').on('click', function() {
    var id = $(this).data('id');
    if (confirm('确定要删除吗?')) {
        $.ajax({
            url: 'delete.php', //处理删除请求的PHP文件
            type: 'POST',
            data: {id: id},
            success: function(res) {
                if (res.code === 0) {
                    alert('删除成功');
                    window.location.reload(); //刷新页面
                } else {
                    alert('删除失败,请稍后再试');
                }
            },
            error: function() {
                alert('请求失败,请稍后再试');
            }
        });
    }
});
Salin selepas log masuk

Dalam kod di atas, kami menggunakan jQuery untuk mengikat acara klik butang padam. Apabila pengguna mengklik butang padam, kami mula-mula mendapat nilai ID data, dan menggunakan fungsi pengesahan untuk memunculkan kotak pengesahan yang bertanya kepada pengguna jika mereka mahu memadamkannya. Jika pengguna mengklik untuk mengesahkan, kami akan menghantar permintaan POST ke fail delete.php untuk memadam data daripada pangkalan data.

Nota: Kod dalam fail delete.php adalah seperti berikut:

<?php
//连接数据库
$dsn = &#39;mysql:host=localhost;dbname=test;charset=utf8&#39;;
$username = &#39;root&#39;;
$password = &#39;123456&#39;;
$options = [
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, //异常处理模式
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, //默认的查询结果类型
];
$pdo = new PDO($dsn, $username, $password, $options);

//删除数据
$id = $_POST['id'];
$sql = "DELETE FROM test_table WHERE id = :id";
$stmt = $pdo->prepare($sql);
$stmt->bindParam(':id', $id, PDO::PARAM_INT);
$res = $stmt->execute();

//返回结果
if ($res) {
    echo json_encode(['code' => 0, 'msg' => '删除成功']);
} else {
    echo json_encode(['code' => 1, 'msg' => '删除失败']);
}
?>
Salin selepas log masuk

Dalam kod di atas, kami mula-mula menyambung ke pangkalan data, dan kemudian menggunakan pernyataan DELETE untuk memadam data daripada pangkalan data. Akhir sekali, kami mengembalikan keputusan dalam format JSON.

3. Ubah suai data

Selain memadamkan data, kita selalunya perlu mengubah suai data. Di bawah, kami akan memperkenalkan cara mengubah suai data melalui tetingkap pop timbul.

  1. Data pertanyaan

Pertama, kita perlu menanyakan data yang perlu diubah suai daripada pangkalan data dan memaparkannya pada halaman untuk memudahkan pengubahsuaian pengguna.

<?php
//连接数据库
$dsn = &#39;mysql:host=localhost;dbname=test;charset=utf8&#39;;
$username = &#39;root&#39;;
$password = &#39;123456&#39;;
$options = [
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, //异常处理模式
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, //默认的查询结果类型
];
$pdo = new PDO($dsn, $username, $password, $options);

//查询要修改的数据
$id = $_GET['id'];
$sql = "SELECT * FROM test_table WHERE id = :id";
$stmt = $pdo->prepare($sql);
$stmt->bindParam(':id', $id, PDO::PARAM_INT);
$stmt->execute();
$data = $stmt->fetch();
?>
Salin selepas log masuk

Dalam kod di atas, kami mula-mula mendapatkan ID data yang perlu diubah suai melalui $_GET['id']. Kemudian, kami menggunakan pernyataan SELECT untuk menanyakan data daripada pangkalan data.

  1. Paparan data

Seterusnya, kami memaparkan data yang ditanya pada halaman untuk memudahkan pengubahsuaian pengguna. Di sini kami masih menggunakan borang HTML untuk mengisi data pertanyaan ke dalam borang.

<form>
    <input type="hidden" name="id" value="<?php echo $data[&#39;id&#39;]; ?>">
    <div>
        <label>Name:</label>
        <input type="text" name="name" value="<?php echo $data[&#39;name&#39;]; ?>">
    </div>
    <div>
        <label>Email:</label>
        <input type="text" name="email" value="<?php echo $data[&#39;email&#39;]; ?>">
    </div>
    <button class="submit-btn">保存</button>
    <button class="cancel-btn" type="button" onclick="history.back()">取消</button>
</form>
Salin selepas log masuk

Perhatikan bahawa kami menambahkan medan tersembunyi pada borang untuk menyimpan nilai ID data yang perlu diubah suai.

  1. Ubah suai data

Akhir sekali, mari kita laksanakan fungsi pengubahsuaian. Apabila pengguna mengklik butang simpan, kami akan menghantar permintaan AJAX untuk mengemas kini data yang diubah suai ke dalam pangkalan data.

$('.submit-btn').on('click', function() {
    var data = $('form').serialize();
    $.ajax({
        url: 'update.php', //处理修改请求的PHP文件
        type: 'POST',
        data: data,
        success: function(res) {
            if (res.code === 0) {
                alert('修改成功');
                window.location.href = 'index.php'; //跳转到列表页
            } else {
                alert('修改失败,请稍后再试');
            }
        },
        error: function() {
            alert('请求失败,请稍后再试');
        }
    });
});
Salin selepas log masuk

Dalam kod di atas, kami menggunakan jQuery untuk mengikat acara klik butang simpan. Apabila pengguna mengklik butang simpan, kami mula-mula mendapatkan semua data dalam borang melalui fungsi bersiri dan menghantarnya ke fail update.php. Di sini kami menggunakan kaedah POST untuk menghantar data.

Nota: Kod dalam fail update.php adalah seperti berikut:

<?php
//连接数据库
$dsn = &#39;mysql:host=localhost;dbname=test;charset=utf8&#39;;
$username = &#39;root&#39;;
$password = &#39;123456&#39;;
$options = [
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, //异常处理模式
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, //默认的查询结果类型
];
$pdo = new PDO($dsn, $username, $password, $options);

//修改数据
$id = $_POST['id'];
$name = $_POST['name'];
$email = $_POST['email'];
$sql = "UPDATE test_table SET name = :name, email = :email WHERE id = :id";
$stmt = $pdo->prepare($sql);
$stmt->bindParam(':id', $id, PDO::PARAM_INT);
$stmt->bindParam(':name', $name, PDO::PARAM_STR);
$stmt->bindParam(':email', $email, PDO::PARAM_STR);
$res = $stmt->execute();

//返回结果
if ($res) {
    echo json_encode(['code' => 0, 'msg' => '修改成功']);
} else {
    echo json_encode(['code' => 1, 'msg' => '修改失败']);
}
?>
Salin selepas log masuk

Dalam kod di atas, kami mula-mula menyambung ke pangkalan data, dan kemudian menggunakan pernyataan UPDATE untuk mengemas kini data ke dalam pangkalan data. Akhir sekali, kami mengembalikan keputusan dalam format JSON.

Perhatikan bahawa untuk kemudahan demonstrasi, di sini kami menggunakan fungsi bersiri untuk menukar data borang kepada rentetan, tetapi dalam projek sebenar, kami biasanya menggunakan objek FormData untuk memproses data borang untuk menyokong fungsi seperti memuat naik fail.

4. Ringkasan

Melalui pengenalan artikel ini, kami telah mempelajari cara mengendalikan pangkalan data melalui tetingkap pop timbul PHP. Sama ada pemadaman atau pengubahsuaian, kita boleh menggunakan kaedah yang sama untuk mencapainya. Saya harap artikel ini dapat memberikan sedikit bantuan kepada pembaca Jika ada apa-apa yang anda masih tidak faham, anda boleh meninggalkan mesej untuk perbincangan.

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

Kenyataan Laman Web ini
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

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah amalan terbaik untuk deduplikasi tatasusunan php Apakah amalan terbaik untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:41 PM

Artikel ini meneroka deduplikasi array PHP yang cekap. Ia membandingkan fungsi terbina dalam seperti array_unique () dengan pendekatan hashmap tersuai, menonjolkan prestasi perdagangan berdasarkan saiz array dan jenis data. Kaedah optimum bergantung pada profili

Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Mar 03, 2025 pm 04:51 PM

Artikel ini meneroka deduplikasi PHP Array menggunakan keunikan utama. Walaupun bukan kaedah penyingkiran pendua langsung, memanfaatkan keunikan utama membolehkan membuat array baru dengan nilai yang unik dengan nilai pemetaan ke kekunci, menimpa duplikat. AP ini

Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Mar 03, 2025 pm 04:47 PM

Artikel ini menganalisis PHP Array Deduplication, menonjolkan kemunculan prestasi pendekatan naif (O (N²)). Ia meneroka alternatif yang cekap menggunakan array_unique () dengan fungsi tersuai, splobjectstorage, dan pelaksanaan hashset, mencapai

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Mar 10, 2025 pm 06:15 PM

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Mar 10, 2025 pm 06:16 PM

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:50 PM

Artikel ini meneroka mengoptimumkan deduplikasi array PHP untuk dataset yang besar. Ia mengkaji teknik-teknik seperti array_unique (), array_flip (), splobjectstorage, dan pra-sorting, membandingkan kecekapan mereka. Untuk dataset besar -besaran, ia mencadangkan pemotongan, pangkalan data

Bagaimana saya bekerja dengan sambungan php dan pecl? Bagaimana saya bekerja dengan sambungan php dan pecl? Mar 10, 2025 pm 06:12 PM

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Mar 10, 2025 pm 06:12 PM

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea

See all articles