Heim  >  Artikel  >  Datenbank  >  MyBatis+MySQL 返回插入记录的主键ID_MySQL

MyBatis+MySQL 返回插入记录的主键ID_MySQL

WBOY
WBOYOriginal
2016-06-01 13:07:48804Durchsuche

今天用到了多个表之间的关系,另一个表中的一个字段要以第一个表的主键作为外键。

下面说两种方法,MyBatis+MySQL 返回插入记录的主键ID:

第一种:

<insert id="insertAndGetId" usegeneratedkeys="true" keyproperty="userId" parametertype="com.chenzhou.mybatis.User">	insert into user(userName,password,comment)	values(#{userName},#{password},#{comment})</insert>

第二种:

<insert id="insert" parametertype="cn.***.beans.LogObject">	<selectkey resulttype="java.lang.Integer" order="BEFORE" keyproperty="id">		SELECT LOGS_SEQ.nextval AS ID FROM DUAL	</selectkey>	INSERT INTO S_T_LOGS (		ID, 		USER_ID, 		USER_NAME, 		USER_IP, 		OPERATION_TIME, 		DESCRIPTION, 		RESOURCE_ID) 	VALUES (		#{id}, 		#{userId}, 		#{userName}, 		#{userIp}, 		#{operationTime}, 		#{description}, 		#{resourceId})</insert>


这两种写法都可以,但有两点一定要注意:

一: keyProperty="id" 这个id必须是实体的id,而不是数据表的主键id,否则,得不到正确的返回结果;

二:接收返回值时候,必须用实体的get属性,而不能定义变量,否则,接收不到正确的返回结果:即必须用user.getId()来接收。


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn