mybatis中insert主键ID获取和多参数传递的示例代码
目录
- 一、插入数据主键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.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 |
selectLAST_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
selectfrom t_user awhere a.email like CONCAT('%', #{email}, '%') anda.sex =#{sex}
2、调用层
Map params = new HashMap(); params.put("email", email); params.put("sex", sex); Listlist1 = mapper.selectByEmailAndSex1(params); System.out.println(list1.size());
2、使用注解传递参数;
特点:直观明了,当参数较少一般小于5个的时候,建议使用;
代码示例
1、xml
selectfrom t_user awhere a.email like CONCAT('%', #{email}, '%') anda.sex = #{sex}
2、调用层
PagestartPage = PageHelper.startPage(2, 3); List list2 = mapper.selectByEmailAndSex2(email, sex); System.out.println(list2.size());
3、使用Java Bean的方式传递参数;
特点:当参数大于5个的时候,建议使用;
代码示例
1、xml
selectfrom t_user awhere a.email like CONCAT('%', #{email}, '%') anda.sex = #{sex}
2、调用层
EmailSexBean esb = new EmailSexBean(); esb.setEmail(email); esb.setSex(sex); Listlist3 = mapper.selectByEmailAndSex3(esb); System.out.println(list3.size());
【mybatis中insert主键ID获取和多参数传递的示例代码】到此这篇关于mybatis中insert主键ID获取和多参数传递的示例代码的文章就介绍到这了,更多相关mybatis多参数传递内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 热闹中的孤独
- Shell-Bash变量与运算符
- JS中的各种宽高度定义及其应用
- 2021-02-17|2021-02-17 小儿按摩膻中穴-舒缓咳嗽
- 深入理解Go之generate
- 异地恋中,逐渐适应一个人到底意味着什么()
- 我眼中的佛系经纪人
- 《魔法科高中的劣等生》第26卷(Invasion篇)发售
- “成长”读书社群招募
- 2020-04-07vue中Axios的封装和API接口的管理