最近做的项目都是存的自增ID,就遇到了一个问题,存到数据库后,怎样马上得到他的主键ID?我之前用的都是UUID,这样的话我能得到主键ID,但是自增的话,就得不到了,我就蒙了,但是今天同事告诉了我一个好的解决方法,分享给大家!首先说一下自增ID和UUID各自的优缺点:
自增主键
自增ID就是在设计标的时候设置AUTO_INCREMENT,就可以实现主键ID自增,能够保证字段的原子性.。
优点
数据库自动编号,速度快,而且是增量增长,按顺序存放,对于检索非常有利;数字型,占用空间小,易排序,在程序中传递也方便;如果通过非系统增加记录时,可以不用指定该字段,不用担心主键重复问题。
缺点
因为自动增长,在手动要插入指定ID的记录时会显得麻烦,尤其是当系统与其它系统集成时,需要数据导入时,很难保证原系统的ID不发生主键冲突(前提是老系统也是数字型的)。
UUID
UUID含义是通用唯一识别码 (Universally Unique Identifier),指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。
优点
出现数据拆分、合并存储的时候,能达到全局的唯一性
缺点
影响插入速度, 并且造成硬盘使用率低,uuid之间比较大小相对数字慢不少, 影响查询速度。uuid占空间大, 如果你建的索引越多, 影响越严重
上述优缺点,仿照一个博主写的,出处: ; 接下来解决咱自己的问题,上代码:
上述中keyProperty 指定对应返回的主键就OK!非常简单,service层取用的时候这样写就可以啦!
希望此篇文章对大家有所帮助!!