http://www.111cn.net/database/110/106fc8201f1219d8e9dd012b626a4317.htm
三种返回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 ......
分享到:
相关推荐
总结一下,MyBatis 中插入数据并返回插入记录的 ID 主要涉及以下知识点: 1. 使用 `<insert>` 标签定义插入语句。 2. 设置 `useGeneratedKeys="true"` 开启获取自增主键的功能。 3. 使用 `keyProperty` 指定对象的...
这个特性在执行插入操作后获取新插入记录的ID时非常有用。例如,在上面的代码中,使用了`@@IDENTITY`来获取刚刚插入的记录ID: ```csharp BackBZID = Convert.ToInt32(TPMySqlHelper.GetSingle("INSERT INTO TP_BZ_...
在Java编程中,JDBC(Java Database Connectivity)...正确地使用预编译的`PreparedStatement`可以提高代码的可读性和安全性,同时,通过设置`RETURN_GENERATED_KEYS`属性,我们可以轻松地获取新插入记录的自增主键值。
"MyBatis insert操作插入数据之后返回插入记录的id" MyBatis是一款流行的Java持久层框架,今天我们将讨论MyBatis insert操作插入数据之后返回插入记录的id的知识点。 首先,MyBatis提供了一个机制来获取插入数据...
防止mysql重复插入记录的方法有很多种,常用的是ignore,Replace,ON DUPLICATE KEY UPDATE,当然我们也可以在php中加以判断了。 方案一:使用ignore关键字 如果是用主键primary或者唯一索引unique区分了记录的唯一性,...
因此,`user.getUserId()`会返回插入后的主键ID。 通过这种方式,我们可以轻松地在插入数据后获取到MySQL生成的自增主键。需要注意的是,这种方法依赖于数据库支持自增主键,并且在某些数据库中(如Oracle),可能...
在Java编程中,当我们在MySQL数据库中执行插入操作并希望获取新插入记录的自增ID时,有多种方法可以实现这一需求。以下是三种常见的方法,适用于不同的场景。 **方法一:使用PreparedStatement的RETURN_GENERATED_...
综合来看,推荐使用`mysql_insert_id()`函数作为首选方法,因为它是专为PHP设计的,易于使用,且在大多数情况下能准确返回新插入记录的ID。在遇到`bigint`类型ID或者特殊需求时,可以考虑使用`LAST_INSERT_ID()`函数...
执行完成后,`order`对象的`id`属性将会被自动填充为刚刚插入记录的自增长ID值。 这个机制对于需要跨表关联的场景特别有用,比如在上述例子中,当我们在订单表中插入客户信息后,可以获取到新生成的订单ID,并将其...
如果是用主键primary或者唯一索引unique区分了记录的唯一性,避免重复插入记录可以使用: 代码如下: INSERT IGNORE INTO `table_name` (`email`, `phone`, `user_id`) VALUES (‘test9@163.com’, ‘99999’, ...
MySQL 雪花算法生成唯一整型ID主键的实现主要针对大数据环境下,需要大量生成全局唯一ID的需求。雪花算法是一种分布式ID生成策略,由Twitter开源,其设计目标是在分布式系统中生成具有全局唯一性、有序性和高并发性...
为了查询历史记录,可以编写一个API端点,从数据库中检索并返回这些记录: ```javascript app.get('/api/messages', (req, res) => { const sql = 'SELECT * FROM messages ORDER BY timestamp DESC'; connection...
在插入新记录前,该触发器会自动为每一行的新记录的`id`字段赋值为序列的下一个值。这种方式更加灵活且无需在每个插入语句中显式指定序列值。 #### 获取刚插入的ID 在Oracle中,如果需要获取刚插入的数据的ID值,...
如果尝试插入的记录与现有记录中的`field1`和`field2`组合相同,MySQL会忽略这次插入操作,不会返回任何错误。 在实际应用中,我们可能通过后端编程语言(如PHP)与数据库交互,或者直接在MySQL客户端中运行SQL命令...
在成功插入数据后,可以通过`mysql_insert_id()`函数获取最后插入记录的ID。注意,这个方法只适用于设置了主键且主键类型为自增的表: ```php echo "ID of last inserted record is: " . mysql_insert_id(); ``` ...
后台Java代码接收到文件后,将其存储到服务器的特定目录,并记录图片的路径信息。 2. **数据存储**:在存储图片的同时,我们需要将图片的路径信息保存到MySQL数据库中。这通常涉及创建一个包含图片路径的数据库表。...
10. **操作语句反馈**:每个查询或操作后,MySQL都会返回一个确认信息,如`Query OK, 0 rows affected (0.00 sec)`,表示操作成功但没有影响任何行。时间如`(0.00 sec)`表示操作所用的时间。 11. **字符集**:字符...
之后,我们调用 `mysql_insert_id()` 来获取新插入记录的ID,并打印出来。 **注意事项** 由于 `mysql_` 系列函数已经被标记为过时,现在推荐使用更安全的 `mysqli_` 或 `PDO` 扩展来进行数据库操作。对于 `mysqli_`...
当使用DataAdapter填充DataSet或DataTable时,可以设置`AcceptChangesDuringFill`属性为`false`,然后在插入新记录后调用`GetChanges`,这将返回一个只包含新插入记录的DataTable,从中获取新ID。 7. **存储过程**...