web-dev-qa-db-fra.com

mysqli dernier identifiant d'insertion

Je voudrais associer l'image avec prénom, nom ... comment puis-je récupérer la dernière ligne et l'utiliser pour l'insérer dans l'autre table? J'ai essayé $image = $mysqli->insert_id; puis contraignant mais cela ne fonctionne pas. Est-ce que quelqu'un peut m'aider?

 $image = $mysqli->insert_id;//this should come from table2
 $stmt = $mysqli->prepare("
  insert into table1 (username, firstname, lastname, image) 
  select ?,?,?,image from table2 t2 where username = ? and  t2.id = ? 
   ");
 $stmt->bind_param('sssss', $username, $fname, $lname, $username, $image);
 $stmt->execute();
14
user2926655

mysqli::$insert_id - mysqli_insert_id - Renvoie l'identifiant généré automatiquement utilisé dans la dernière requête, Exemple:

$mysqli = new mysqli("localhost", "my_user", "my_password", "world");

/* check connection */
if (mysqli_connect_errno()) {
    printf("Connect failed: %s\n", mysqli_connect_error());
    exit();
}

$mysqli->query("CREATE TABLE myCity LIKE City");

$query = "INSERT INTO myCity VALUES (NULL, 'Stuttgart', 'DEU', 'Stuttgart', 617000)";
$mysqli->query($query);

printf ("New Record has id %d.\n", $mysqli->insert_id);

/* drop table */
$mysqli->query("DROP TABLE myCity");

/* close connection */
$mysqli->close();

production

Le nouvel enregistrement a l'identifiant 1.

Référence

21
Abdallah Alhabarneh

Tout d'abord, vous devez créer un champ d'incrémentation automatique dans votre I'D

Ensuite, vous pouvez utiliser $last_id = mysqli_insert_id($conn);

10
Rathod Paresh

après avoir obtenu la dernière ligne de table2, je voudrais l'insérer dans table1. C'est tout ce dont j'ai besoin

Continue:

  1. insérer dans le tableau 1 avec simple requête d'insertion régulière
  2. obtenir le dernier identifiant d'insertion
  3. insérer dans le tableau 2 avec simple requête d'insertion régulière

Aussi simple que cela

1