Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Harus Menyimpan dan Mengurus Tatasusunan PHP dalam Pangkalan Data Perhubungan?

Bagaimanakah Saya Harus Menyimpan dan Mengurus Tatasusunan PHP dalam Pangkalan Data Perhubungan?

Susan Sarandon
Lepaskan: 2024-12-09 05:17:16
asal
411 orang telah melayarinya

How Should I Store and Manage PHP Arrays in a Relational Database?

Amalan Terbaik: Penyimpanan Data Perhubungan dan Pengendalian Tatasusunan PHP

Menyimpan tatasusunan dalam satu medan MySQL biasanya tidak disyorkan. Sebaliknya, anda dinasihatkan untuk menganalisis model data anda dan menyusun semula model tersebut dengan sewajarnya. Walau bagaimanapun, jika anda mesti menyimpan tatasusunan dalam satu medan, pertimbangkan pilihan berikut:

Serialization dan Unserialization:

Menggunakan serialize() dan unserialize() PHP fungsi boleh menukar tatasusunan menjadi rentetan, yang kemudiannya boleh disimpan dalam medan MySQL. Walau bagaimanapun, anda tidak akan dapat melakukan pertanyaan pada kandungan tertentu dalam tatasusunan.

Pengekodan dan Penyahkodan JSON:

Sebagai alternatif, anda boleh menggunakan json_encode() dan json_decode() fungsi. Fungsi ini menyediakan pendekatan yang lebih moden dan berstruktur untuk mensiri dan menyahsiri data.

Pertimbangkan tatasusunan berikut:

$a = array(
    1 => array(
        'a' => 1,
        'b' => 2,
        'c' => 3
    ),
    2 => array(
        'a' => 1,
        'b' => 2,
        'c' => 3
    ),
);
Salin selepas log masuk

Untuk penyimpanan dan manipulasi pangkalan data yang optimum, anda harus menyusun semula model data anda. Cipta jadual dengan lajur berasingan untuk setiap pasangan nilai kunci dalam tatasusunan, seperti:

DROP TABLE IF EXISTS test;
CREATE TABLE test (
    id         INTEGER UNSIGNED NOT NULL,
    a          INTEGER UNSIGNED NOT NULL,
    b          INTEGER UNSIGNED NOT NULL,
    c          INTEGER UNSIGNED NOT NULL,
    PRIMARY KEY (id)
);
Salin selepas log masuk

Anda boleh menggunakan fungsi PHP untuk berinteraksi dengan pangkalan data:

// Connect to the database
$c = mysql_connect($server, $username, $password);
mysql_select_db('test');

// Example functions to interact with the database
function getTest() {
    $ret = array();
    $query = 'SELECT * FROM test';
    $r = mysql_query($query,$c);
    while ($o = mysql_fetch_array($r,MYSQL_ASSOC)) {
        $ret[array_shift($o)] = $o;
    }
    mysql_close($c);
    return $ret;
}

function putTest($t) {
    foreach ($t as $k => $v) {
        $query = "INSERT INTO test (id,".
                implode(',',array_keys($v)).
                ") VALUES ($k,".
                implode(',',$v).
            ")";
        $r = mysql_query($query,$c);
    }
    mysql_close($c);
}

// Insert the array into the database
putTest($a);

// Retrieve the data from the database
$b = getTest();
Salin selepas log masuk

Dengan menerima pakai model data hubungan, anda boleh memastikan storan, pertanyaan dan manipulasi data anda yang cekap.

Atas ialah kandungan terperinci Bagaimanakah Saya Harus Menyimpan dan Mengurus Tatasusunan PHP dalam Pangkalan Data Perhubungan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan