首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MyBatis + MySQL返回插入成功的主键id

这是最近在实现perfect-ssm中的一个功能时碰到的一个小问题,觉得需要记录一下,向MySQL数据库中插入一条记录,需要获取此条记录的id值,以生成对应的key值存入到redis中,id为自增int...articleCreateDate},#{articleContent},#{addName}) 这种方式只是返回一个影响行数值,并不能满足此次需求,于是做了如下修改: <insert id...#{articleContent},#{addName}) 在insert中将useGeneratedKeys属性设置为true,并制定keyProperty为Article对象的id...=null); System.out.println("insertarticle的id:"+article.getId()); } 结果如下: ?...mysql中表的记录如下: ? 结语 首发于我的个人博客,新的项目演示地址:perfect-ssm,登录账号:admin,密码:123456 ?

4K60

关于mysql自增id获取和重置

转载请注明出处:帘卷西风的专栏(http://blog.csdn.net/ljxfblog) ---- mysql获取自增id的几种方法 使用max函数:select max(id) from tablename...缺点:获取的不是真正的自增id,是表中最大的Id,如果有删除数据的话,那么该值和自增id相差比较大。如果有连表数据,有可能导致数据错乱。...使用LAST_INSERT_ID函数:select LAST_INSERT_ID() 优点:获取到的是真正的自增id。 缺点:该函数是与table无关的,永远保留最新插入的自增列的id。...所以需要额外的操作来获取。 使用自定义查询方法:mysql表相关的信息是放在information_schema表里。所以我们参考 SHOW TABLE STATUS来构建查询语句。...也不会清空数据,有可能会出现重复key的可能,所以此方法也只适用于清空表之后重置自增id或者大量删除修改自增id

11.7K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL蜜罐获取攻击者微信ID

    利用 抓个包看看连MySQL时客户端和服务端通信的两个关键点: 服务端先返回了版本、salt等信息: ? 客户端向服务端发送账号密码信息,服务端返回了认证成功的包: ?...日常生活中,大家几乎都会使用微信,而如果攻击者没有做到办公—渗透环境分离的话,我们就有希望获取到攻击者的微信ID Windows下,微信默认的配置文件放在C:\Users\username\Documents...伪装 攻击者进入内网常常会进行主机发现和端口扫描,如果扫到MySQL了,是有可能进行爆破的,如果蜜罐不能让扫描器识别出是弱口令,那就没啥用了,所以还需要抓下扫描器的包。...可以看到,这款工具在验证完密码还发了5个查询包,如果结果不对的话,是无法识别出弱口令的,那么我们将服务器的响应数据提取出来,放进程序里,当收到这些请求,就返回对应的包: ?...写了个简单的web来显示攻击者的微信ID,扫一扫就能加上TA ? 思考 除了获取微信ID,我们还能获取哪些有价值的东西呢?

    1.8K40

    如何在MySQL现有表中添加自增ID

    当在MySQL数据库中,自增ID是一种常见的主键类型,它为表中的每一行分配唯一的标识符。在某些情况下,我们可能需要在现有的MySQL表中添加自增ID,以便更好地管理和索引数据。...在本文中,我们将讨论如何在MySQL现有表中添加自增ID,并介绍相关的步骤和案例。图片创建新的自增ID添加自增ID列是在现有表中添加自增ID的一种常见方法。...添加自增ID列并填充数据在添加自增ID,我们还需要为现有数据填充ID值。...约束和索引:在添加自增ID,确保为该列添加适当的约束和索引,以保证数据的完整性和查询的效率。...数据一致性:添加自增ID列可能需要对现有数据进行更新操作,确保在进行更新之前备份数据,并小心处理可能出现的冲突或错误。结论在本文中,我们讨论了如何在MySQL现有表中添加自增ID

    1.6K20

    Mysql实现获取自增id插入到其他表中

    现在有这样一个需求,就是我向A表中插入一条数据,id是自增的。...插入之后,还需要向B表中插入一条数据,但是B表中需要保存的数据中要使用刚刚A表自增id, 这个其实是一个比较常见的需求,就是两张表之间的一个关联,如果用程序来执行也是很容易实现。...比如我就在用sql执行之后,获取A的id插入到B表中 实现方式如下: insert into A (id,name,code) values (null, "zhagnsan", "zs"); // 注意...A表的id要设置为自增,给null值即可 set @id = @@IDENTITY; // 使用id变量保存刚刚自增生成的id insert into B (id,a_id,name) values...(null, @id, "lisi"); // 使用变量获取A表Id 上面是用自定义变量的形式进行保存的,如果你只是想查一下是多少,可以直接使用: select @@IDENTITY; 好了,如果对你有帮助

    4K30

    mysql实现获取自增id插入到其他表中

    现在有这样一个需求,就是我向A表中插入一条数据,id是自增的。...插入之后,还需要向B表中插入一条数据,但是B表中需要保存的数据中要使用刚刚A表自增id, 这个其实是一个比较常见的需求,就是两张表之间的一个关联,如果用程序来执行也是很容易实现。...比如我就在用sql执行之后,获取A的id插入到B表中 实现方式如下: insert into A (id,name,code) values (null, "zhagnsan", "zs"); // 注意...A表的id要设置为自增,给null值即可 set @id = @@IDENTITY; // 使用id变量保存刚刚自增生成的id insert into B (id,a_id,name) values...(null, @id, "lisi"); // 使用变量获取A表Id 上面是用自定义变量的形式进行保存的,如果你只是想查一下是多少,可以直接使用: select @@IDENTITY; 好了,如果对你有帮助

    3.5K20

    MySQL 对已存在数据表添加自增 ID 字段

    系统环境:Ubuntu 数据库:MySQL5.7 主要是遗留问题,该表本来只是用于分析,同事没有添加自增id,造成后续在处理时,遇到一些问题,权衡之后,决定对表新增一个自增的id字段(表中已经存在大量数据...sed每行行首添加空字符 sed 's/^/""^&/g' all_202106.txt > all_20210602.txt 将上面导出的数据,通过sed命令,给每行行首添加一个空字符,并以“^”分割...后面通过设置数据库ID为自增,为每个ID生成唯一标识。...LOAD DATA导入MySQL LOAD DATA local INFILE '/var/lib/mysql-files/all_20210602.txt' IGNORE INTO TABLE 库命....至此,对已存在数据库表添加自增ID操作完成。导出,添加行首空字符,再导入MySQL一共花费3个小时左右时间,基本都花费在导出和导入。

    3.5K10

    MySQL自增主键id重启重复使用问题解析

    如果在此过程中删除部分数据,那么MySQL重启再插入数据,自增主键ID是否会重复使用呢?本文将通过具体示例,解析MySQL自增主键id在重启是否重复使用的问题。...值: sql INSERT INTO t(num) VALUES (18); SELECT * FROM t; 可以看到,重启MySQL插入的新记录id为18,并没有重复使用已经删除的15,16,17...四、原理解析 MySQL的自增主键id重启后为什么没有重复使用呢?...MySQL服务器重启,会读取信息架构表中的auto_increment值,以确定下一个自增id,从而避免了已经使用的id重复分配问题。...idIncrement,避免单表过大 vivo_tmp_xxx临时表可用于生成id,避免影响线上表自增值六、总结MySQL的自增主键id在重启不会重复使用已经删除的id,这是由其自动保存并恢复auto_increment

    98010
    领券