1. 程式人生 > >時獲取Mysql自增主鍵的值及Oracle非自增主鍵的值

時獲取Mysql自增主鍵的值及Oracle非自增主鍵的值

<insert>

parameterType:引數型別,可以省略, 
1、獲取自增主鍵的值:
        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>

2、獲取非自增主鍵的值

mysql支援自增,但Oracle不支援自增;Oracle使用序列來模擬自增;每次插入的資料的主鍵是從序列中拿到的值;

    keyProperty:查出的主鍵值封裝給javaBean的哪個屬性
        order="BEFORE":當前sql在插入sql之前執行
        order=" AFTER":當前sql在插入sql之後執行
        resultType:查出的資料的返回值型別
        
        BEFORE執行順序:
            先執行selectKey查詢id的sql;查出id值封裝給javaBean的id屬性
            在執行插入的sql;就可以取出id屬性對應的值
        AFTER執行順序:
            先執行插入的sql(從序列中取出新值作為id);
            再執行selectKey查詢id的sql;

<insert id="addEmp" databaseId="oracle">
		<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>

1和2對應介面方法是一個,但是分別對應一個數據庫

public void addEmp(Employee employee);

Java程式碼中獲取返回的id值,直接從物件中獲取

Employee employee = new Employee(null, "jerry4",null, "1");
mapper.addEmp(employee);
System.out.println(employee.getId());

注意:mybatis允許增刪改直接定義以下型別返回值,因為增刪改都是影響的具體行數,可以返回影響的行數
           Integer、Long、Boolean、void