mysqli::$insert_id

mysqli_insert_id

(PHP 5)

mysqli::$insert_id -- mysqli_insert_idВозвращает автоматически генерируемый ID, используя последний запрос

Описание

Объектно-ориентированный стиль

Процедурный стиль

mixed mysqli_insert_id ( mysqli $link )

Функция mysqli_insert_id() возвращает ID, генерируемый запросом к таблице, которая содержит колонку с атрибутом AUTO_INCREMENT. Если последний запрос не был INSERT или UPDATE или в модифицируемой таблице отсутствует колонка с атрибутом AUTO_INCREMENT, данная функция вернет ноль.

Замечание:

Выполнение выражения INSERT или UPDATE, используя функцию LAST_INSERT_ID(), также изменяет значение, возвращаемое функцией mysqli_insert_id().

Список параметров

link

Только для процедурного стиля: Идентификатор соединения, полученный с помощью mysqli_connect() или mysqli_init()

Возвращаемые значения

Значение поля AUTO_INCREMENT, которое было затронуто предыдущим запросом. Возвращает ноль, если предыдущий запрос не затронул таблицы, сожержащие поле AUTO_INCREMENT.

Замечание:

Если число больше максимального значения int, функция mysqli_insert_id() вернет строку.

Примеры

Пример #1 Пример функции $mysqli->insert_id

Объектно-ориентированный стиль

<?php
$mysqli 
= new mysqli("localhost""my_user""my_password""world");

/* проверка соединения */
if (mysqli_connect_errno()) {
    
printf("Соединение не установлено: %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 ("ID новой записи: %d.\n"$mysqli->insert_id);

/* удаление таблицы */
$mysqli->query("DROP TABLE myCity");

/* закрытие соединения */
$mysqli->close();
?>

Процедурный стиль

<?php
$link 
mysqli_connect("localhost""my_user""my_password""world");

/* проверка соединения */
if (mysqli_connect_errno()) {
    
printf("Соединение не установлено: %s\n"mysqli_connect_error());
    exit();
}

mysqli_query($link"CREATE TABLE myCity LIKE City");

$query "INSERT INTO myCity VALUES (NULL, 'Stuttgart', 'DEU', 'Stuttgart', 617000)";
mysqli_query($link$query);

printf ("ID новой записи: %d.\n"mysqli_insert_id($link));

/* удаление таблицы */
mysqli_query($link"DROP TABLE myCity");

/* закрытие соединения */
mysqli_close($link);
?>

Результат выполнения данных примеров:

ID новой записи: 1.

Коментарии

I was having problems with getting the inserted id, and did a bit of testing. It ended up that if you commit a transaction before getting the last inserted id, it returns 0 every time, but if you get the last inserted id before committing the transaction, you get the correct value.
2004-11-03 13:44:00
http://php5.kiev.ua/manual/ru/mysqli.insert-id.html
I have received many statements that the insert_id property has a bug because it "works sometimes".  Keep in mind that when using the OOP approach, the actual instantiation of the mysqli class will hold the insert_id. 

The following code will return nothing.
<?php
$mysqli 
= new mysqli('host','user','pass','db');
if (
$result $mysqli->query("INSERT INTO t (field) VALUES ('value');")) {
   echo 
'The ID is: '.$result->insert_id;
}
?>

This is because the insert_id property doesn't belong to the result, but rather the actual mysqli class.  This would work:

<?php
$mysqli 
= new mysqli('host','user','pass','db');
if (
$result $mysqli->query("INSERT INTO t (field) VALUES ('value');")) {
   echo 
'The ID is: '.$mysqli->insert_id;
}
?>
2006-04-20 21:40:16
http://php5.kiev.ua/manual/ru/mysqli.insert-id.html
Автор:
When running extended inserts on a table with an AUTO_INCREMENT field, the value of mysqli_insert_id() will equal the value of the *first* row inserted, not the last, as you might expect.

<?
//mytable has an auto_increment field
$db->query("INSERT INTO mytable (field1,field2,field3) VALUES ('val1','val2','val3'),
('val1','val2','val3'),
('val1','val2','val3')"
);

echo 
$db->insert_id//will echo the id of the FIRST row inserted
?>
2007-05-04 04:10:09
http://php5.kiev.ua/manual/ru/mysqli.insert-id.html
Watch out for the oo-style use of $db->insert_id. When the insert_id exceeds 2^31 (2147483648) fetching the insert id renders a wrong, too large number. You better use the procedural mysqli_insert_id( $db ) instead.

[EDIT by danbrown AT php DOT net: This is another prime example of the limits of 32-bit signed integers.]
2008-07-22 11:58:08
http://php5.kiev.ua/manual/ru/mysqli.insert-id.html
The example is lack of insert_id in multi_query. Here is my example:
Assuming you have a new test_db in mysql like this:

create database if not exists test_db;
use test_db;
create table user_info (_id serial, name varchar(100) not null);
create table house_info (_id serial, address varchar(100) not null);

Then you run a php file like this:

<?php
define
('SERVER''127.0.01');
define('MYSQL_USER''your_user_name');
define('MYSQL_PASSWORD''your_password');

$db = new mysqli(SERVERMYSQL_USERMYSQL_PASSWORD"test_db"3306);
if (
$db->connect_errno)
  echo 
"create db failed, error is "$db->connect_error;
else {
 
$sql "insert into user_info "
   
"(name) values "
   
"('owen'), ('john'), ('lily')";
  if (!
$result $db->query($sql))
    echo 
"insert failed, error: "$db->error;
  else
    echo 
"last insert id in query is "$db->insert_id"\n";
 
$sql "insert into user_info"
   
"(name) values "
   
"('jim');";
 
$sql .= "insert into house_info "
   
"(address) values "
   
"('shenyang')";
  if (!
$db->multi_query($sql))
    echo 
"insert failed in multi_query, error: "$db->error;
  else {
    echo 
"last insert id in first multi_query is "$db->insert_id"\n";
    if (
$db->more_results() && $db->next_result())
      echo 
"last insert id in second multi_query is "$db->insert_id"\n";
    else
      echo 
"insert failed in multi_query, second query error is "$db->error;
  }
 
$db->close();
}
?>

You will get output like this:

last insert id in query is 1
last insert id in first multi_query is 4
last insert id in second multi_query is 1

Conclusion:
1 insert_id works in multi_query
2 insert_id is the first id mysql has used if you have insert multi values
2013-09-06 05:54:24
http://php5.kiev.ua/manual/ru/mysqli.insert-id.html
Hi Dears,

msqli_insert_id() simply does not ALWAYS return the correct value.

Use it only, if you performed some inserts just before. Then you get what you want.

In all other cases: may be, may be not.

I never found out why and why not. 

I'm now performing a query like this:
SELECT MAX(`id`) FROM `table`

(by calling mysqli_query() in procedural style, for OO may be similar.) 

It' s simple and  reliable - if you have set your id colum to "auto-increment". (if not: hm, why not??);
2014-01-20 14:37:14
http://php5.kiev.ua/manual/ru/mysqli.insert-id.html
Hi  mail at nikha dot org,

I must say your way of getting the key is not correct. Consider a multi user situation where everyone is registering and you are returning their id. Let's say A, B and C are registering at the same time.

Regards
Himadri
2016-03-18 14:31:24
http://php5.kiev.ua/manual/ru/mysqli.insert-id.html
msqli_insert_id();
This seems to return that last id entered.
BUT,  if you have multiple users running the same code, depending on the server or processor I have seen it return the wrong id.

Test Case:
Two users added an item to their list.
I have had a few times where the id was the id from the other user. 
This is very very rare and it only happens on my test server and not my main server.

I am guessing it is because of multicores (maybe hyperthreading) or how the operating system handles multi-threads.

It is rare, but it happens.
2017-01-19 05:35:29
http://php5.kiev.ua/manual/ru/mysqli.insert-id.html
When using "INSERT ... ON DUPLICATE KEY UPDATE `id` = LAST_INSERT_ID(`id`)", the AUTO_INCREMENT will increase in an InnoDB table, but not in a MyISAM table.
2019-05-26 06:54:13
http://php5.kiev.ua/manual/ru/mysqli.insert-id.html

    Поддержать сайт на родительском проекте КГБ