三种返回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 ......
分享到:
相关推荐
最后,文章总结了该实例对于Python3操作MySQL数据库插入数据并获取主键id的实践价值,并鼓励大家进行学习和参考,同时建议对于多线程并发操作的场景,应当考虑使用多进程来保证数据的一致性和操作的安全性。...
### Oracle插入数据时获取自增ID 在Oracle数据库中,当需要实现类似其他数据库系统(如MySQL、SQL Server等)中的自动增长字段功能时,通常会采用序列(sequence)和触发器(trigger)来实现这一需求。下面将详细...
,当出现重复插入的情况,MySQL 会返回 Affected rows: 0,表示插入的数据为 0 条,并且 id 的值不是连续的。二是使用 on duplicate key update 语句,例如 insert into userinfo(nickname, openid) VALUE (ENCRYPT...
在这个例子中,`your_table`是你要插入数据的表名,`column1`和`column2`是表中的字段名,`value1`和`value2`是对应的插入值。`PreparedStatement`允许我们使用占位符`?`,然后通过`setXXX()`方法设置实际值,以防止...
"MyBatis insert操作插入数据之后返回插入记录的id" MyBatis是一款流行的Java持久层框架,今天我们将讨论MyBatis insert操作插入数据之后返回插入记录的id的知识点。 首先,MyBatis提供了一个机制来获取插入数据...
根据提供的文件信息,我们可以归纳出以下几个...总结来说,通过分析这段代码,我们可以了解到MySQL中查询和插入的基本用法,以及如何利用这些技术来实现数据复制和更新。这对于日常的数据库管理和维护工作非常有帮助。
总结来说,PHP插入MySQL数据并返回ID主要通过以下步骤完成: 1. 连接MySQL数据库。 2. 执行SQL插入语句。 3. 使用`mysql_insert_id()`获取新生成的自增ID。 然而,需要注意的是,`mysql_*`系列函数在PHP 7.0版本后...
总结一下,MyBatis 中插入数据并返回插入记录的 ID 主要涉及以下知识点: 1. 使用 `<insert>` 标签定义插入语句。 2. 设置 `useGeneratedKeys="true"` 开启获取自增主键的功能。 3. 使用 `keyProperty` 指定对象的...
当一个新记录被插入并自动分配了一个ID时,`mysql_insert_id()` 将返回这个新ID。如果上一个查询没有创建 AUTO_INCREMENT ID,该函数将返回0。 **语法** ```php mysql_insert_id([connection]) ``` 参数 `...
因此,它是获取新插入数据ID的高效方法,尤其是在处理大量数据插入时。 7. **错误处理** 总是确保在尝试获取插入ID之前,插入操作已经成功执行。如果插入失败,`mysqli_insert_id()`和`PDO::lastInsertId()`可能会...
我们可以按照分区的原则,向表里插入数据。每个分区有4条数据,查询结果正确。 分区删除 我们可以使用命令`alter table tuser drop partition p1;`删除第一个分区,分区内的数据也将被删除。 新建分区 我们可以...
然而,在某些特定情况下,比如在批量插入数据时,可能需要获取每条数据自增后的ID。由于Beego ORM的默认行为并不直接支持这种需求,开发者需要自定义方法来实现这一功能。本文将详细讲解如何在Go和Beego框架中自写一...
MySQL 雪花算法生成唯一整型ID主键的实现主要针对大数据环境下,需要大量生成全局唯一ID的需求。雪花算法是一种分布式ID生成策略,由Twitter开源,其设计目标是在分布式系统中生成具有全局唯一性、有序性和高并发性...
user.setComment("测试插入数据返回主键功能"); System.out.println("插入前主键为:" + user.getUserId()); int insertedId = userDao.insertAndGetId(user); System.out.println("插入后主键为:" + user....
13. 插入数据时使用SELECT INTO:可以用来创建新表,并将数据一次性插入新表中,这是一个高效的数据复制和迁移的方法。 14. 优化JOIN操作:在进行表连接时,应当先选择小表进行连接,然后在结果集上连接大表,以...
在Java编程中,当我们在MySQL数据库中执行插入操作并希望获取新插入记录的自增ID时,有多种方法可以实现这一需求。以下是三种常见的方法,适用于不同的场景。 **方法一:使用PreparedStatement的RETURN_GENERATED_...
在MySQL数据库操作中,插入数据是基础且至关重要的任务,这允许我们向表格中添加新的记录。本篇文章主要探讨了如何使用SQL语句`INSERT`来实现数据的插入,包括四种基本方法:插入完整的行、插入行的一部分、插入多行...
在MySQL中,选择插入数据是一种常见的操作,用于将一个或多个源表的数据插入到目标表中。这个过程涉及到SQL查询的SELECT和INSERT语句的结合使用。在这个具体实现的例子中,我们看到用户尝试将`table_b`中的数据插入...