app开发者平台在数字化时代的重要性与发展趋势解析
683
2023-02-04
mybatis中insert主键ID获取和多参数传递的示例代码
一、插入数据主键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 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})
该插入指令会取出主键并由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、代码示例
select
LAST_INSERT_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})
二、查询如何传入多个参数
1、使用map传递参数;
特点:可读性差,导致可维护性和可扩展性差,杜绝使用;
代码示例
1、xml
select
from t_user a
where a.email like CONCAT('%', #{email}, '%') and
a.sex =#{sex}
2、调用层
Map
params.put("email", email);
params.put("sex", sex);
List
System.out.println(list1.size());
2、使用注解传递参数;
特点:直观明了,当参数较少一般小于5个的时候,建议使用;
代码示例
1、xml
select
from t_useLIDaYuqr a
where a.email like CONCAT('%', #{email}, '%') and
a.sex = #{sex}
2、调用层
Page
List
System.out.println(list2.size());
3、使用java Bean的方式传递参数;
特点:当参数大于5个的时候,建议使用;
代码示例
1、xml
parameterType="com.enjoylearning.mybatis.entity.EmailSexBean">
select
from t_user a
where a.email like CONCAT('%', #{email}, '%') and
a.sex = #{sex}
2、调用层
EmailSexBean esb = new EmailSexBean();
esb.setEmail(email);
esb.setSex(sex);
List
System.out.println(list3.size());
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~