mysql中添加一条记录的函数_三种返回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 ......

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值