ホームページ > データベース > mysql チュートリアル > MyBatis+MySQL 返回插入记录的主键ID_MySQL

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

WBOY
リリース: 2016-06-01 13:07:48
オリジナル
843 人が閲覧しました

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

下面说两种方法,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()来接收。


ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート