主鍵自增與不自增的主鍵返回

<mapper namespace="test">  
        <insert id="insertUser" parameterType="dancheng.mybatis.po.User">  
            <!-- keyProperty:將查詢出的主鍵設置到parameterType中的哪一個屬性上 order:相對於sql語句的執行順序 resultType:指定返回值類型 LAST_INSERT_ID():獲取ID函數 -->  
            <selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer"> SELECT LAST_INSERT_ID() </selectKey> insert into user(username,birthday,sex,address) value(#{username},#{birthday},#{sex},#{address}) </insert>  
    </mapper>  

 

    <mapper namespace="test">  
        <insert id="insertUser" parameterType="dancheng.mybatis.po.User">  
            <!-- keyProperty:將查詢出的主鍵設置到parameterType中的哪一個屬性上 order:相對於sql語句的執行順序 resultType:指定返回值類型 LAST_INSERT_ID():獲取ID函數 -->  
            <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String"> SELECT uuid() </selectKey> insert into user(id,username,birthday,sex,address) value(#{id}.#{username},#{birthday},#{sex},#{address}) </insert>  
    </mapper>

oracle主鍵返回
<insert id="insertUser" parameterType="cn.itcast.mybatis.po.User">
	<selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String">
		SELECT 序列名.nextval() FROM DUAL;
	</selectKey>
	insert into user(id,username,birthday,sex,address) value(#{id},#{username},#{birthday},#{sex},#{address})
  </insert>
 

主鍵返回

mysql 主鍵返回值
 
(1)主鍵返回之自增主鍵

 

 


(2)主鍵返回值UUID

UUID函數是mysql的函數html


 

 


Oracle主鍵返回值

(1)序列也就是sequence,它是Oracle的主鍵生成策略java

 


 (2)mysql

<insert id="insert" parameterType="com.xxx.SystemDepartment">
    <selectKey keyProperty="id" resultType="String" order="BEFORE">
        select sys_guid() from dual
    </selectKey>
    insert into SYSTEM_DEPARTMENT (ID,DEPNAME, SUPERID, SORT, STATE)
    values ( #{id,jdbcType=VARCHAR},#{depname,jdbcType=VARCHAR},
    #{superid,jdbcType=DECIMAL}, #{sort,jdbcType=DECIMAL},
    #{state,jdbcType=DECIMAL})
</insert>
相關文章
相關標籤/搜索