mybatis的@Options注解能够设置缓存时间,能够为对象生成自增的key;
场景:
一个表id(主键)设置为自增,而当我们需要在dao层插入数据的时候立刻获取到该自动生成的id;
实现:如下
@Insert("insert into instance (infos)"
+ " ("
+ " @{infos},"
+ " NOW()"
+ ")")
@Options(useGeneratedKeys = true, keyProperty = "instanceId", keyColumn = "instance_id")
int addInstance(Instance instance);
@Options注解中默认设置的主键对应的字段名为id,在我们的表中,主键名为instance_id,因此需要将keyProperty和keyColumn设置成我们想要的字段:instanceId instance_id
注解意义:从instance_id这个字段里面把数据放到传入对象的instanceId成员变量里面。
注意:我们传入的对象(如上例子)是没有设置id的。数据库的自增,使得该逻辑成立,不需要设置也能插入。当使用options注解时,使得该传入的对象加上了前面插入自动生成的id。所以想要获取该id的值,只需要从对象取出即可;