Mybatis六种传参方式

原文点击此处

1. 顺序传参

  • 优点:减少代码量
  • 缺点:必须按照顺序传参

Mapper代码

User getUserByParam(String phone, String password);

xml代码

<select id="getUserByParam" resultType="com.example.demo.model.User">
        select `user_id`,`real_name`,`nick_name`,`sex`,`phone`,`password` from bss_user
        where `phone` = #{param1} and `password` = #{param2}
</select>

2. 使用@Param传参

  • @Param为该参数属性赋予key
  • 如果1-4个参数使用该方式,超过推荐map或实体类

mapper代码

    User getUserByParam(@Param("key1") String phone, @Param("key2") String password);

xml代码

    <select id="getUserByParam" resultType="com.example.demo.model.User">
        select `user_id`,`real_name`,`nick_name`,`sex`,`phone`,`password` from bss_user
        where `phone` = #{key1} and `password` = #{key2}
    </select>

3. 使用Map传参

mapper代码

User getUserByParam(Map<String, Object> params);

xml代码

    <select id="getUserByParam" resultType="com.example.demo.model.User">
        select `user_id`,`real_name`,`nick_name`,`sex`,`phone`,`password` from bss_user
        where `phone` = #{phone} and `password` = #{password}
    </select>

4. 使用@Param和Map组合传参

  • 如果超过4个参数推荐使用该方式

mapper代码

User getUserByParam(@Param("params") Map<String, Object> params);

xml代码

    <select id="getUserByParam" resultType="com.example.demo.model.User">
        select `user_id`,`real_name`,`nick_name`,`sex`,`phone`,`password` from bss_user
        where `phone` = #{params.phone} and `password` = #{params.password}
    </select>

5. 使用实体类传参

mapper代码

User getUserByParam(User user);

xml代码

    <select id="getUserByParam" resultType="com.example.demo.model.User">
        select `user_id`,`real_name`,`nick_name`,`sex`,`phone`,`password` from bss_user
        where `phone` = #{phone} and `password` = #{password}
    </select>

6. List传参

mapper代码

User getUserByParam(List<User> paramList);

xml代码

    <select id="getUserByParam" resultType="com.example.demo.model.User">
        select `user_id`,`real_name`,`nick_name`,`sex`,`phone`,`password` from bss_user
        where
        <foreach collection="list" item="item" separator=",">
            `phone` = #{item.phone} and `password` = #{item.password}
        </foreach>
    </select>

还可参考以下文章:

参考文章一:https://www.cnblogs.com/mike-mei/p/13265942.html

参考文章二:https://blog.csdn.net/u014292162/article/details/52079615

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值