mybatis中的options注解

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的值,只需要从对象取出即可;

猜你喜欢

转载自blog.csdn.net/qq_33999844/article/details/82972300
今日推荐