Rumah pembangunan bahagian belakang masalah PHP Bagaimana untuk menyimpan tatasusunan ke dalam pangkalan data dalam php

Bagaimana untuk menyimpan tatasusunan ke dalam pangkalan data dalam php

Apr 23, 2023 am 10:07 AM

Apabila menggunakan PHP untuk pembangunan web, biasanya kita perlu menyimpan beberapa data dalam pangkalan data untuk kegunaan seterusnya. Jenis data yang paling biasa digunakan ialah tatasusunan.

Seterusnya, mari kita terokai cara menyimpan tatasusunan ke dalam pangkalan data.

  1. Sediakan pangkalan data

Pertama, kita perlu mencipta jadual untuk menyimpan data tatasusunan kita. Mengambil MySQL sebagai contoh, terdapat langkah berikut:

1) Cipta pangkalan data, seperti test.

2) Buat jadual di bawah pangkalan data, seperti array_data, untuk menyimpan data tatasusunan kami. Pernyataan SQL berikut boleh digunakan:

CREATE TABLE `array_data` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `data` text NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
Salin selepas log masuk

Jadual mengandungi dua medan, iaitu id dan data. Antaranya, id ialah kunci utama, digunakan untuk mengenal pasti secara unik sekeping data; medan data digunakan untuk menyimpan data tatasusunan yang ingin kami simpan.

  1. Tukar tatasusunan kepada rentetan

Sebelum menyimpan tatasusunan dalam pangkalan data, kita perlu menukarnya kepada rentetan. Kerana hanya data jenis rentetan boleh disimpan dalam pangkalan data. Untuk menukar tatasusunan kepada rentetan, anda boleh menggunakan fungsi serialize() yang disediakan oleh PHP.

Sebagai contoh, kami mempunyai data tatasusunan berikut:

$data = [
    'name' => 'Tom',
    'age' => 25,
    'gender' => 'male'
];
Salin selepas log masuk

Anda boleh menggunakan fungsi serialize() untuk menukarnya menjadi rentetan:

$data_str = serialize($data);
Salin selepas log masuk

Di kali ini, $data_str Nilainya ialah:

a:3:{s:4:"name";s:3:"Tom";s:3:"age";i:25;s:6:"gender";s:4:"male";}
Salin selepas log masuk
  1. Tulis data ke pangkalan data

Menyimpan rentetan ke dalam pangkalan data adalah sangat mudah. Kita boleh menggunakan sambungan PDO PHP untuk menyambung ke pangkalan data dan kemudian menggunakan pernyataan yang disediakan untuk menulis data ke pangkalan data.

Kod khusus adalah seperti berikut:

try {
    $dsn = "mysql:host=localhost;dbname=test;charset=utf8mb4";
    $username = "root";
    $password = "";

    $pdo = new PDO($dsn, $username, $password);
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

    $data = [
        'name' => 'Tom',
        'age' => 25,
        'gender' => 'male'
    ];
    $data_str = serialize($data);

    $stmt = $pdo->prepare("INSERT INTO array_data (data) VALUES (?)");
    $stmt->bindParam(1, $data_str);
    $stmt->execute();
} catch (PDOException $e) {
    echo $e->getMessage();
}
Salin selepas log masuk

Dalam kod di atas, kita mula-mula mencipta objek PDO, dan kemudian menggunakan fungsi prepare() untuk mencipta pernyataan yang disediakan. Antaranya, ? menunjukkan bahawa kedudukan semasa memerlukan parameter, dan kami menghantar rentetan untuk disimpan sebagai parameter. Akhir sekali, gunakan fungsi execute() untuk melaksanakan pernyataan yang disediakan.

  1. Baca data tatasusunan daripada pangkalan data

Apabila kita perlu membaca data tatasusunan dalam pangkalan data, mula-mula kita boleh membaca rentetan yang disimpan daripada pangkalan data, dan kemudian Gunakan fungsi unserialize() untuk menukarnya kepada tatasusunan.

Kod khusus adalah seperti berikut:

try {
    $dsn = "mysql:host=localhost;dbname=test;charset=utf8mb4";
    $username = "root";
    $password = "";

    $pdo = new PDO($dsn, $username, $password);
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

    $stmt = $pdo->query("SELECT data FROM array_data WHERE id = 1");
    $data_str = $stmt->fetchColumn();

    $data = unserialize($data_str);

    print_r($data);
} catch (PDOException $e) {
    echo $e->getMessage();
}
Salin selepas log masuk

Dalam kod di atas, kami menggunakan fungsi query() untuk melaksanakan pernyataan SQL dan menggunakan fungsi fetchColumn() untuk mendapatkan semula lajur pertama data daripada set hasil, iaitu A rentetan yang memegang data tatasusunan kami. Kemudian, gunakan fungsi unserialize() untuk menukarnya kepada jenis tatasusunan.

Akhir sekali, gunakan fungsi print_r() untuk mengeluarkan data tatasusunan.

Ringkasan

Dalam program PHP, menyimpan tatasusunan ke dalam pangkalan data biasanya dibahagikan kepada langkah berikut:

  1. Sediakan pangkalan data dan cipta jadual jenis teks medan .
  2. Tukar tatasusunan kepada rentetan.
  3. Simpan rentetan ke dalam pangkalan data.
  4. Baca rentetan daripada pangkalan data dan tukarkannya kepada tatasusunan menggunakan fungsi unserialize().

Atas ialah kandungan terperinci Bagaimana untuk menyimpan tatasusunan ke dalam pangkalan data dalam 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)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Akan R.E.P.O. Ada Crossplay?
1 bulan 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)

PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. Mar 25, 2025 am 10:37 AM

Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum. Mar 26, 2025 pm 04:13 PM

Artikel ini membincangkan kelemahan OWASP 10 dalam strategi PHP dan mitigasi. Isu -isu utama termasuk suntikan, pengesahan yang rosak, dan XSS, dengan alat yang disyorkan untuk memantau dan mendapatkan aplikasi PHP.

PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail. Mar 26, 2025 pm 04:18 PM

Artikel ini membincangkan mendapatkan muat naik fail PHP untuk mengelakkan kelemahan seperti suntikan kod. Ia memberi tumpuan kepada pengesahan jenis fail, penyimpanan selamat, dan pengendalian ralat untuk meningkatkan keselamatan aplikasi.

Penyulitan PHP: Penyulitan simetri vs asimetrik. Penyulitan PHP: Penyulitan simetri vs asimetrik. Mar 25, 2025 pm 03:12 PM

Artikel ini membincangkan penyulitan simetri dan asimetrik dalam PHP, membandingkan kesesuaian, prestasi, dan perbezaan keselamatan mereka. Penyulitan simetri lebih cepat dan sesuai untuk data pukal, manakala asimetrik digunakan untuk pertukaran utama yang selamat.

Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Pengesahan PHP & amp; Kebenaran: Pelaksanaan selamat. Mar 25, 2025 pm 03:06 PM

Artikel ini membincangkan pelaksanaan pengesahan dan kebenaran yang mantap dalam PHP untuk mencegah akses yang tidak dibenarkan, memperincikan amalan terbaik dan mengesyorkan alat peningkatan keselamatan.

PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. PHP CSRF Perlindungan: Bagaimana untuk mencegah serangan CSRF. Mar 25, 2025 pm 03:05 PM

Artikel ini membincangkan strategi untuk mencegah serangan CSRF di PHP, termasuk menggunakan token CSRF, kuki tapak yang sama, dan pengurusan sesi yang betul.

PHP API Kadar Mengehadkan: Strategi Pelaksanaan. PHP API Kadar Mengehadkan: Strategi Pelaksanaan. Mar 26, 2025 pm 04:16 PM

Artikel ini membincangkan strategi untuk melaksanakan kadar API yang mengehadkan PHP, termasuk algoritma seperti baldi token dan baldi bocor, dan menggunakan perpustakaan seperti simfoni/kadar-limiter. Ia juga meliputi pemantauan, had kadar penyesuaian secara dinamik, dan tangan

Apakah tujuan penyataan yang disediakan dalam PHP? Apakah tujuan penyataan yang disediakan dalam PHP? Mar 20, 2025 pm 04:47 PM

Kenyataan yang disediakan dalam PHP meningkatkan keselamatan pangkalan data dan kecekapan dengan mencegah suntikan SQL dan meningkatkan prestasi pertanyaan melalui kompilasi dan penggunaan semula.

See all articles