萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> 三種返回mysql 插入一條記錄返回該記錄id方法

三種返回mysql 插入一條記錄返回該記錄id方法

三種返回mysql教程 插入一條記錄返回該記錄id方法

方法一

id int(11) not null pri key auto_increment,name varchar(12),backup varchar(50)
現在想插入一條記錄的同時,返回他的id值(插入時只是插入name和backup字段的值)。請問該如何寫這條語句。謝謝!

你的擔心完全多於。 不需要鎖表, 返回的ID肯定是你的,基於當前連接session

自動返回最後一個INSERT或 UPDATE 問詢為 AUTO_INCREMENT列設置的第一個 發生的值。

mysql> SELECT LAST_INSERT_ID();

        -> 195

產生的ID 每次連接後保存在服務器中。這意味著函數向一個給定客戶端返回的值是該客戶端產生對影響AUTO_INCREMENT列的最新語句第一個 AUTO_INCREMENT值的。這個值不能被其它客戶端影響,即使它們產生它們自己的 AUTO_INCREMENT值。這個行為保證了你能夠找回自己的 ID 而不用擔心其它客戶端的活動,而且不需要加鎖或處理。
 

mysql的源代碼裡面,mysql_insert_id是這麼定義的
my_ulonglong STDCALL mysql_insert_id(MYSQL *mysql)
{
  return mysql->;last_used_con->;insert_id;
}

MYSQL提供給c++,php教程等的API一般,有個MYSQL結構體。
結構體裡面有insert_id, insert_id的類型 my_ulonglong。 其實就是long long.

每次mysql_query操作在mysql服務器上可以理解為一次“原子”操作, 數據庫教程的寫操作常常需要鎖表的, 是mysql應用服務器鎖表不是我們的應用程序鎖表。

 

方法二

Mysql提供了一個LAST_INSERT_ID()的函數。

LAST_INSERT_ID() (with no argument) returns the first automatically generated value that was set for an AUTO_INCREMENT column by the most recently executed INSERT or UPDATE statement to affect such a column. For example, after inserting a row that generates an AUTO_INCREMENT value, you can get the value like this:

mysql> SELECT LAST_INSERT_ID();
        -> 195簡單說來,就是這個函數將返回插入的那條記錄在表中自增的那個字段的值,一般我們都給那個自增字段命名為ID。這樣就可以返回剛插入的記錄的ID值了。

一個簡單的例子:

$query="INSERT INTO `testtable` (`clou1`,`clou2`) VALUES ('testvalue','test')";
mysql_query($query);
$query="SELECT LAST_INSERT_ID()";
$result=mysql_query($query);
$rows=mysql_fetch_row($result);
echo $rows[0];這樣就可以返回剛插入的記錄的ID值了。
值得注意的是,如果你一次插入了多條記錄,這個函數返回的是第一個記錄的ID值。

mysql> INSERT INTO t VALUES
    -> (NULL, 'Mary'), (NULL, 'Jane'), (NULL, 'Lisa');
Query OK, 3 rows affected (0.00 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> SELECT * FROM t;
+----+------+
| id | name |
+----+------+
|  1 | Bob  |
|  2 | Mary |
|  3 | Jane |
|  4 | Lisa |
+----+------+
4 rows in set (0.01 sec)

mysql> SELECT LAST_INSERT_ID();
+------------------+
| LAST_INSERT_ID() |
+------------------+
|                2 |
+------------------+
1 row in set (0.00 sec)這個函數是基於connection的,也就是不會被其他客戶端的connection影響到,所以結果是准確的。如果使用select max(id) from table,在高密度的插入請求下,是有可能出問題的,返回錯誤值。

方法三

.select max(id) from user;
2.select last_insert_id() as id from user limit 1; 
(這個測試的返回id一直是0,有點問題)
3.儲存過程
1)
oracel中
create sequence seqID
minvalue 1
maxvalue 999999999999999999999999999
start with 1
increment by 1
nocache
order;
create or replace procedure sp_insert(aName int,rst out int) is
begin
  insert into tablename(id,name) values(seqID.nextval,aName);
  rst:=seqID.currval;
end;
2)mysql中實現
DELIMITER $$
DROP PROCEDURE IF EXISTS `test` $$
CREATE DEFINER=`root`@`localhost` PROCEDURE `test`(in name varchar(100),out oid int)
BEGIN
  insert into user(loginname) values(name);
  select max(id) from user into oid;
  select oid;
END $$
DELIMITER ;
然後執行
call test('gg',@id);
就返回id ......

copyright © 萬盛學電腦網 all rights reserved