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

作者:Dark_King_ 时间:2023-09-20 07:11:00 

一、插入数据主键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());

来源:https://blog.csdn.net/b379685397/article/details/114634063

标签:mybatis,多参数,传递
0
投稿

猜你喜欢

  • Android框架Volley使用:ImageRequest请求实现图片加载

    2022-03-01 11:30:06
  • 详解Kotlin中的面向对象(二)

    2021-12-29 03:10:00
  • C#使用webbrowser的常见用法实例

    2023-06-14 13:57:45
  • 详解使用IntelliJ IDEA新建Java Web后端resfulAPI模板

    2023-12-14 09:26:04
  • C#实现XSL转换的方法

    2023-02-02 03:36:41
  • ListView 分页加载更新实例分享

    2021-09-05 06:53:11
  • C#实现导出List数据到xml文件的方法【附demo源码下载】

    2022-02-13 10:32:14
  • Triple协议支持Java异常回传设计实现详解

    2021-08-16 17:16:09
  • Bootstrap 下拉菜单.dropdown的具体使用方法

    2023-07-08 19:10:46
  • Java中ResultSetMetaData 元数据的具体使用

    2021-06-25 12:38:13
  • Android Service启动流程刨析

    2023-07-31 11:28:58
  • C#无损转换Image为Icon的方法

    2023-07-30 02:38:40
  • OpenCV实现平均背景法

    2023-06-28 18:25:41
  • c#实现metro文件压缩解压示例

    2022-07-07 22:36:33
  • 百度人脸识别之人脸识别FaceIdentify(签到考勤)

    2022-08-24 18:25:03
  • C#清除字符串内空格的方法

    2023-10-07 15:51:04
  • Android第三方微信支付教程

    2022-03-13 23:38:40
  • C#实现获取机器码的示例详解

    2021-11-13 06:57:19
  • Java事件监听机制讲解

    2022-09-18 00:41:11
  • mybatis教程之延迟加载详解

    2023-02-19 12:45:18
  • asp之家 软件编程 m.aspxhome.com