mybatis 中mapper.xml中屬性

  1. parameterType: 參數類型, 可以省略
  2. mysql支持自增主鍵,自增主鍵的獲取, mybatis也是利用statement.getGenreatedKeys();
    useGeneratedKeys=”true”;使用自增主鍵獲取主鍵值策略
    keyProperty;指定對應的主鍵屬性,也就是mybatis獲取到主鍵值以後,將這個值封裝給javaBean的哪個屬性
   <insert id="addEmp" parameterType="com.atguigu.mybatis.bean.Employee"
        useGeneratedKeys="true" keyProperty="id" databaseId="mysql">
        insert into tbl_employee(last_name,email,gender) 
        values(#{lastName},#{email},#{gender})
    </insert>

獲取非自增主鍵的值:
Oracle不支持自增;Oracle使用序列來模擬自增;
每次插入的數據的主鍵是從序列中拿到的值;如何獲取到這個值;

<insert id="addEmp" databaseId="oracle">
        <!-- 
        keyProperty:查出的主鍵值封裝給javaBean的哪個屬性
        order="BEFORE":當前sql在插入sql之前運行
               AFTER:當前sql在插入sql之後運行
        resultType:查出的數據的返回值類型

        BEFORE運行順序:
            先運行selectKey查詢id的sql;查出id值封裝給javaBean的id屬性
            在運行插入的sql;就可以取出id屬性對應的值
        AFTER運行順序:
            先運行插入的sql(從序列中取出新值作爲id);
            再運行selectKey查詢id的sql;
         -->
        <selectKey keyProperty="id" order="BEFORE" resultType="Integer">
            <!-- 編寫查詢主鍵的sql語句 -->
            <!-- BEFORE-->
            select EMPLOYEES_SEQ.nextval from dual 
            <!-- AFTER:
             select EMPLOYEES_SEQ.currval from dual -->
        </selectKey>

        <!-- 插入時的主鍵是從序列中拿到的 -->
        <!-- BEFORE:-->
        insert into employees(EMPLOYEE_ID,LAST_NAME,EMAIL) 
        values(#{id},#{lastName},#{email<!-- ,jdbcType=NULL -->}) 
        <!-- AFTER:
        insert into employees(EMPLOYEE_ID,LAST_NAME,EMAIL) 
        values(employees_seq.nextval,#{lastName},#{email}) -->
    </insert>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章