Mysql数据库使用触发器实现获取当前Insert数据的ID值
在开发过程中,遇到了保存记录网页上列表显示顺序的问题,且这个顺序页面上是可以修改的。如下图所示:
那么问题来了,如何实现记录顺序呢?
我采用了最简单的方法,就是在数据库中添加了一个字段,叫做xx_order,int类型就不用说了,但是问题又来了,每次Insert一条数据后,我该如何记录当前的数据的order?
于是在网上四处搜索,了解到如下结论:
1. 数据库中可以使用默认自增的形式为此数据添加顺序,但是Mysql数据库(目前只接触了Mysql数据库)并不支持两列数据的自增长,也就是说,如果主键使用了自增长,那这样的想法就不必继续了。
2. 可以采用触发器实现获取当前Insert语句的ID值,然后使得_order的值等于这个id值,就可以记录顺序了。
3. 在创建Insert触发器的时候,必须使用Before,且新增的一行数据就叫做new,比如new.order就表示本次Inser的表中的order字段名。
4.由于使用了Before,就意味着在Insert之前获取该数据的id,但是此时sql还没有提交,所以无