Mybatis獲取數據庫自增主鍵


一般我們都為將表中主鍵列設置為自增,當我們執行插入語句時,比如這樣

//測試添加
Employee employee = new Employee(null, "jerry4",null, "1");
mapper.addEmp(employee);
System.out.println(employee.getId());

那此時主鍵列我們進行`null值插入,插入后,如何能夠獲取自增的主鍵呢?

一、mybatis獲取mysql自增主鍵

只需要關注mapper.xml中的sql語句

	<!-- public void addEmp(Employee employee); -->
	<!-- parameterType:參數類型,可以省略, 
	獲取自增主鍵的值:
		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>

二、mybatis獲取Oracle自增主鍵

	<!-- 
	獲取非自增主鍵的值:
		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>

加油,努力學習Oracle !


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM