mybatis开发要点-insert主键ID获取和多参数传递,一个Java应届生从上海离职

本文介绍了在MyBatis中如何通过insert语句获取自增主键ID,并展示了使用selectKey标签的用法。同时,探讨了在查询时如何传递多个参数,比较了使用Map和注解方式的优缺点,并提供了相应的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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 CONCA

《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》

【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享

T(’%’, #{email}, ‘%’) and

a.sex =#{sex}

2、调用层

Map<String, Object> params = new HashMap<String, Object>();

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());

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值