mybatis开发要点-insert主键ID获取和多参数传递
创始人
2024-03-20 17:35:15
0

1.2、代码示例

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

1、使用map传递参数;

2、使用注解传递参数;

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


一、插入数据主键ID获取

============

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

1、Insert/update


1.1、属性解释

useGeneratedKeys

(仅对 insert 和 update 有用)这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键(比如:像 MySQL 和 SQL Server 这样的关系数据库管理系统的自动递增字段),默认值:false。

keyP

roperty

(仅对 insert 和 update 有用)唯一标记一个属性,MyBatis 会通过 getGeneratedKeys 的返回值或者通过 insert 语句的 selectKey 子元素设置它的键值,默认:unset。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。

  • 注意:自增长序号不是简单的行数+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 = new HashMap();

params.put(“email”, email);

params.put(“sex”, sex);

List list1 = mapper.selectByEmailAndSex1(params);

System.out.println(list1.size());

2、使用注解传递参数;


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

代码示例

1、xml

select

from t_user a

where a.email like CONCAT(‘%’, #{email}, ‘%’) and

a.sex = #{sex}

2、调用层

Page startPage = PageHelper.startPage(2, 3);

List list2 = mapper.selectByEmailAndSex2(email, sex);

System.out.println(list2.size());

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


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

代码示例

2、调用层

Page startPage = PageHelper.startPage(2, 3);

List list2 = mapper.selectByEmailAndSex2(email, sex);

System.out.println(list2.size());

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


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

代码示例

相关内容

热门资讯

汽车油箱结构是什么(汽车油箱结... 本篇文章极速百科给大家谈谈汽车油箱结构是什么,以及汽车油箱结构原理图解对应的知识点,希望对各位有所帮...
美国2年期国债收益率上涨15个... 原标题:美国2年期国债收益率上涨15个基点 美国2年期国债收益率上涨15个基...
嵌入式 ADC使用手册完整版 ... 嵌入式 ADC使用手册完整版 (188977万字)💜&#...
重大消息战皇大厅开挂是真的吗... 您好:战皇大厅这款游戏可以开挂,确实是有挂的,需要了解加客服微信【8435338】很多玩家在这款游戏...
盘点十款牵手跑胡子为什么一直... 您好:牵手跑胡子这款游戏可以开挂,确实是有挂的,需要了解加客服微信【8435338】很多玩家在这款游...
senator香烟多少一盒(s... 今天给各位分享senator香烟多少一盒的知识,其中也会对sevebstars香烟进行解释,如果能碰...
终于懂了新荣耀斗牛真的有挂吗... 您好:新荣耀斗牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信8435338】很多玩家在这款游戏...
盘点十款明星麻将到底有没有挂... 您好:明星麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【5848499】很多玩家在这款游戏...
总结文章“新道游棋牌有透视挂吗... 您好:新道游棋牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【7682267】很多玩家在这款游...
终于懂了手机麻将到底有没有挂... 您好:手机麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【8435338】很多玩家在这款游戏...