信息发布→ 登录 注册 退出

mybatis中insert主键ID获取和多参数传递的示例代码

发布时间:2026-01-11

点击量:
目录
  • 一、插入数据主键ID获取
    • 1、Insert/update
      • 1.1、属性解释
      • 1.2、代码示例
    • 2、selectKey
      •  1.1、属性解释
      • 1.2、代码示例
  • 二、查询如何传入多个参数
    • 1、使用map传递参数;
      • 2、使用注解传递参数;
        • 3、使用Java Bean的方式传递参数;

        一、插入数据主键ID获取

        一般我们在做业务开发时,经常会遇到插入一条数据并使用到插入数据的ID情况。如果先插入在查询的话需要多一次sql查询,未免效率太低。因此mybatis也有提供插入数据并返回主键ID的方式。如下

        1、Insert/update

        1.1、属性解释

        keyProperty

        selectKey 语句结果应该被设置的目标属性。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。

        resultType

        结果的类型。MyBatis 通常可以推算出来,但是为了更加确定写上也不会有什么问题。MyBatis 允许任何简单类型用作主键的类型,包括字符串。如果希望作用于多个生成的列,则可以使用一个包含期望属性的 Object 或一个 Map。

        order

        这可以被设置为 BEFORE 或 AFTER。如果设置为 BEFORE,那么它会首先选择主键,设置 keyProperty 然后执行插入语句。如果设置为 AFTER,那么先执行插入语句,然后获取主键字段;mysql数据库自增长的方式order设置为After,oracle数据库通过sequnce获取主键order设置为Before

        注意:自增长序号不是简单的行数+1,而是序号最大值+1;既当前10000条数据,但主键ID到12000,则返回的为12001.而不是10001.

        1.2、代码示例

        <insert id="insert1" parameterType="TUser" useGeneratedKeys="true"	keyProperty="id">
        		insert into t_user (id, userName, realName,
        		sex, mobile,
        		email,
        		note, position_id)
        		values (#{id,jdbcType=INTEGER},
        		#{userName,jdbcType=VARCHAR},
        		#{realName,jdbcType=VARCHAR},
        		#{sex,jdbcType=TINYINT}, #{mobile,jdbcType=VARCHAR},
        		#{email,jdbcType=VARCHAR},
        		#{note,jdbcType=VARCHAR},
        		#{position.id,jdbcType=INTEGER})
        	</insert>

        该插入指令会取出主键并由ID字段来接收

        2、selectKey

         1.1、属性解释

        keyProperty

        selectKey 语句结果应该被设置的目标属性。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。

        resultType

        结果的类型。MyBatis 通常可以推算出来,但是为了更加确定写上也不会有什么问题。MyBatis 允许任何简单类型用作主键的类型,包括字符串。如果希望作用于多个生成的列,则可以使用一个包含期望属性的 Object 或一个 Map。

        order

        这可以被设置为 BEFORE 或 AFTER。如果设置为 BEFORE,那么它会首先选择主键,设置 keyProperty 然后执行插入语句。如果设置为 AFTER,那么先执行插入语句,然后获取主键字段;mysql数据库自增长的方式order设置为After,oracle数据库通过sequnce获取主键order设置为Before

        1.2、代码示例

        <insert id="insert2" parameterType="TUser">
         
        		<selectKey keyProperty="id" order="AFTER" resultType="int">
        			select
        			LAST_INSERT_ID()
        		</selectKey>
        		insert into t_user (id, userName, realName,
        		sex, mobile,
        		email,
        		note,
        		position_id)
        		values (#{id,jdbcType=INTEGER},
        		#{userName,jdbcType=VARCHAR},
        		#{realName,jdbcType=VARCHAR},
        		#{sex,jdbcType=TINYINT}, #{mobile,jdbcType=VARCHAR},
        		#{email,jdbcType=VARCHAR},
        		#{note,jdbcType=VARCHAR},
        		#{position.id,jdbcType=INTEGER})
        	</insert>

        二、查询如何传入多个参数

        1、使用map传递参数;

        特点:可读性差,导致可维护性和可扩展性差,杜绝使用;

        代码示例

        1、xml

        <select id="selectByEmailAndSex1" resultMap="BaseResultMap"		parameterType="map">
        		select
        		<include refid="Base_Column_List" />
        		from t_user a
        		 where a.email like CONCAT('%', #{email}, '%') and
        		 a.sex =#{sex}
        	</select>

        2、调用层

        Map<String, Object> params = new HashMap<String, Object>();
        		params.put("email", email);
        		params.put("sex", sex);
        		List<TUser> list1 = mapper.selectByEmailAndSex1(params);
        		System.out.println(list1.size());

        2、使用注解传递参数;

        特点:直观明了,当参数较少一般小于5个的时候,建议使用;

        代码示例

        1、xml

        <select id="selectByEmailAndSex2" resultMap="BaseResultMap">
        		select
        		<include refid="Base_Column_List" />
        		from t_user a
        		where a.email like CONCAT('%', #{email}, '%') and
        		a.sex =	#{sex}
        	</select>

        2、调用层

        Page<TUser> startPage = PageHelper.startPage(2, 3);
        		List<TUser> list2 = mapper.selectByEmailAndSex2(email, sex);
        		System.out.println(list2.size());

        3、使用Java Bean的方式传递参数;

        特点:当参数大于5个的时候,建议使用;

        代码示例

        1、xml

        <select id="selectByEmailAndSex3" resultMap="BaseResultMap"
        		parameterType="com.enjoylearning.mybatis.entity.EmailSexBean">
        		select
        		<include refid="Base_Column_List" />
        		from t_user a
        		where a.email like CONCAT('%', #{email}, '%') and
        		a.sex =	#{sex}
        	</select>

        2、调用层

        EmailSexBean esb = new EmailSexBean();
        		esb.setEmail(email);
        		esb.setSex(sex);
        		List<TUser> list3 = mapper.selectByEmailAndSex3(esb);
        		System.out.println(list3.size());
        在线客服
        服务热线

        服务热线

        4008888355

        微信咨询
        二维码
        返回顶部
        ×二维码

        截屏,微信识别二维码

        打开微信

        微信号已复制,请打开微信添加咨询详情!