sql >> Databasteknik >  >> RDS >> Mysql

MySQL - Hur man infogar i flera tabeller med främmande nycklar

Du kan göra det på tre metoder:

Första &Rekommenderas. ANVÄNDA SELECT I INSERT-VÄRDET:

Andra. ANVÄNDER LAST_INSERT_ID I INFOGA VÄRDET:

INSERT INTO a (id)
     VALUES ('anything');
INSERT INTO user_details (id, weight, height)
     VALUES (LAST_INSERT_ID(),83, 185);

Tredje. ANVÄNDA PHP SCRIPT

<?php
// Connecting to database
$link = mysql_connect($wgScriptsDBServerIP, $wgScriptsDBServerUsername, $wgScriptsDBServerPassword, true);
if(!$link || [email protected]_SELECT_db($wgScriptsDBName, $link)) {
echo("Cant connect to server");
    exit;
}

// Values to insert
$name = 'John Smith';
$weight = 83;
$height = 185;

// insertion to user table
$sql = "INSERT INTO user (name) VALUES ('$name')";
$result = mysql_query( $sql,$conn );
// retrieve last id
$user_id = mysql_insert_id( $conn );
mysql_free_result( $result );

// insertion to user_details table
$sql = "INSERT INTO user_details (id, weight, height) VALUES ($user_id, $weight, $height)";
$result = mysql_query( $sql,$conn );
mysql_free_result( $result );
?>


  1. Slå in några indata med dess kryssruta och skicka till databasen

  2. MySQL-licens och GPL

  3. MySQL - Vilken Hash Algo ska jag använda för detta?

  4. Uppdatera två olika rader i en rad i SQL