Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Harus Menyimpan dan Mengurus Tatasusunan PHP dalam Pangkalan Data Perhubungan?
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 ), );
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) );
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();
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!