Mybatis自动生成id,以及insert语句什么时候需要写id字段?什么时候不需要写id字段?

mybatis可以使用useGeneratedKeys来自动生成id(其他数字的值也一样可以):

    	<insert id="save" parameterType="UserAlias" useGeneratedKeys="true" keyProperty="id">
	        INSERT INTO userinfo(username,age)
	        VALUES
	        (#{username}, #{age})
        </insert>

上面的代码是针对mysql,在数据库中设置了id自增长的示例。

keyProperty这里指定自动增长的字段,我这里是id。所以下边的insert中可以不写id字段,前提是数据库中一定要设置好id的自增长。

如果数据库中没有设置自增长可以用下面代码:

<insert id="save" parameterType="UserAlias" useGeneratedKeys="true" keyProperty="id">
	<selectKey keyProperty="id" resultType="long" order="BEFORE">
    	SELECT if(max(id) is null,1,MAX(id) + 1 ) as id from userinfo
    </selectKey>
    INSERT INTO userinfo(id,username,age)
    VALUES (#{id}, #{username}, #{age})
</insert>

这时候的insert语句就要写上id字段喽。
这儿,我们就简单提一下 这个元素节点吧:

<selectKey
        <!-- selectKey 语句结果应该被设置的目标属性。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。 -->
        keyProperty="id"
        <!-- 结果的类型。MyBatis 通常可以推算出来,但是为了更加确定写上也不会有什么问题。MyBatis 允许任何简单类型用作主键的类型,包括字符串。如果希望作用于多个生成的列,则可以使用一个包含期望属性的 Object 或一个 Map。 -->
        resultType="int"
        <!-- 这可以被设置为 BEFORE 或 AFTER。如果设置为 BEFORE,那么它会首先选择主键,设置 keyProperty 然后执行插入语句。如果设置为 AFTER,那么先执行插入语句,然后是 selectKey 元素 - 这和像 Oracle 的数据库相似,在插入语句内部可能有嵌入索引调用。 -->
        order="BEFORE"
        <!-- 与前面相同,MyBatis 支持 STATEMENT,PREPARED 和 CALLABLE 语句的映射类型,分别代表 PreparedStatement 和 CallableStatement 类型。 -->
        statementType="PREPARED">

你可能感兴趣的:(mybatis)