三种返回mysql 插入一条记录返回该记录id方法上海

 

id int(11) not null pri key auto_increment,name varchar(12),backup varchar(50)
现在想插入一条记录的同时,返回他的id值(插入时只是插入name和backup字段的值)。请问该如何写这条语句。谢谢!

二 用以下函数:

  返回最后一次查询中使用的自动生成 id,如果是多表插入,返回的是第一个被插入的id。

三种返回mysql教程 插入一条记录返回该记录id方法

msyql_insert_id();

 mysqli_free_result()

 

使用这种方法时 我们得到得是 id最大的值 的确时最后一个 但当多链接线程时这个最大的id并不一定是 我们插入的所以这个不利用域线程。

mysqli_query($con,"INSERT INTO websites (name,url,alexa) 
VALUES ('菜鸟教程','http://www.runoob.com',5633)");

// 输出自动生成的 ID
echo "新 id 为: " . mysqli_insert_id($con); 

一个简单的例子:

当系统执行完INSERT后,再执行SELECT时,可能已经被分发到了不同的后端服务器,如果你使用的编程语言是PHP的话,此时应该通过 mysql_insert_id()来得到最新插入的id,每次INSERT结束后,其实对应的autoincrement值就已经计算好返回给PHP 了,你无需再发出一次独立的查询,直接用mysql_insert_id()就可以了这个函数很好用 当我们插入一条语句时 它自动返回了 最后的id值并且此函数 仅对当前链接有用 也就是说 它是多用户安全型的所以我们经常用此函数;

mysql> SELECT LAST_INSERT_ID();

三:用一下查询

Mysql提供了一个LAST_INSERT_ID()的函数。

mysql_query("select max(id) from t1",$link);

mysql> SELECT LAST_INSERT_ID();
        -> 195简单说来,就是这个函数将返回插入的那条记录在表中自增的那个字段的值,一般我们都给那个自增字段命名为ID。这样就可以返回刚插入的记录的ID值了。

您可能感兴趣的文章:

  • 解析sql中得到刚刚插入的数据的id
  • ThinkPHP写数组插入与获取最新插入数据ID实例
  • php插入mysql数据返回id的方法
  • THINKPHP在添加数据的时候获取主键id的值方法
  • PHP用mysql_insert_id()函数获得刚插入数据或当前发布文章的ID
  • php 生成唯一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 插入数据时 很多时候 我们想知道刚刚插入数据的id 这对我们很有用 下面我说出常用的三种方法并一一分析其利与弊。

mysql的源代码里面,mysql_insert_id是这么定义的
my_ulonglong STDCALL mysql_insert_id(MYSQL *mysql)
{
  return mysql->;last_used_con->;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:

last_insert_id() 是mysql 一个函数 也是 对当前链接起效此用法 解决了 mysql_insert_id () 中遇到的 bigint 型问题。

方法一

但此函数有一个问题 就是 当id 为bigint 型时 就不在起作用了 所以 现在 正在用此函数的请小心了不过 我们平时很少遇到这样的问题,所以可以不用管它。

        -> 195

msyql_query("select last_insert_id()");

自动返回最后一个INSERT或 UPDATE 问询为 AUTO_INCREMENT列设置的第一个 发生的值。

一 用以下语句:

.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 ......

以上这篇php获得刚插入数据的id 的几种方法总结就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

每次mysql_query操作在mysql服务器上可以理解为一次“原子”操作, 数据库教程的写操作常常需要锁表的, 是mysql应用服务器锁表不是我们的应用程序锁表。

你的担心完全多于。 不需要锁表, 返回的ID肯定是你的,基于当前连接session

产生的ID 每次连接后保存在服务器中。这意味着函数向一个给定客户端返回的值是该客户端产生对影响AUTO_INCREMENT列的最新语句第一个 AUTO_INCREMENT值的。这个值不能被其它客户端影响,即使它们产生它们自己的 AUTO_INCREMENT值。这个行为保证了你能够找回自己的 ID 而不用担心其它客户端的活动,而且不需要加锁或处理。  

mysql> SELECT LAST_INSERT_ID();
------------------
| LAST_INSERT_ID() |
------------------
|                2 |
------------------
1 row in set (0.00 sec)这个函数是基于connection的,也就是不会被其他客户端的connection影响到,所以结果是准确的。如果使用select max(id) from table,在高密度的插入请求下,是有可能出问题的,返回错误值。

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

MYSQL提供给c ,php教程等的API一般,有个MYSQL结构体。
结构体里面有insert_id, insert_id的类型 my_ulonglong。 其实就是long long.

方法三

插入一条记录返回该记录id方法 方法一 id int(11) not null pri key auto_increment,name varchar(12),backup varchar(50) 现在想插...

$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 插入一条记录返回该记录id方法上海

您可能还会对下面的文章感兴趣: