MyBatis常用动态SQL语句

本文介绍MyBatis中动态SQL的应用,包括条件查询、插入、删除及更新操作。通过具体示例展示如何灵活地使用if等标签实现复杂的业务逻辑。

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

MyBatis常用动态SQL语句

作者:不染心

时间:2022/5/25

profession类的属性如下:

public class Profession {
    private int id;
    private String pro_name;
    private String pro_id;
    private String nourish_id;
}

一、查询

查询操作中<if test="id!=-1 and id!=0">会根据属性id值判断是否执行将id作为查询条件之一,该查询SQL语句可以作为搜索功能接口,如果搜索功能输入的条件之一为空就不将其作为查询条件。

	<!-- 查询操作 -->
    <select id="selectProfessionByConditions" resultType="Profession" parameterType="Profession">
        select * from `profession`
        <where>
            <if test="id!=-1 and id!=0">
                AND id = #{id}
            </if>
            <if test="pro_name!=null and pro_name!=''">
                AND pro_name = #{pro_name}
            </if>
            <if test="pro_id!=null and pro_id!=''">
                AND pro_id = #{pro_id}
            </if>
            <if test="nourish_id!=null and nourish_id!=''">
                AND nourish_id = #{nourish_id}
            </if>
        </where>
    </select>
	<!--联表查询-->
    <select id="selectProNouByConditions" resultType="ProfessionNourish">
        select a.id, a.pro_name, a.pro_id, a.nourish_id, b.nourish_name, b.finish_weight 
        from `profession` a, `nourish` b where a.nourish_id = b.nourish_id
    </select>

二、插入

	<!-- 插入数据 -->
    <insert id="addProfession" parameterType="Profession">
        INSERT INTO `profession` (`pro_name`, `pro_id`, `nourish_id`) 
        VALUES(#{pro_name}, #{pro_id}, #{nourish_id})
    </insert>

三、删除

	 <!-- 删除操作 -->
    <delete id="delProfessionById">
        delete from `profession` where id = #{id}
    </delete>

四、更新

更新语句中使用if语句判断属性值是否为空,如果不为空就更新该属性值,否则不更新。

	<!--  更新操作  -->
    <update id="updateProfessionById" parameterType="Profession">
        update `profession`
        <set>
            <if test="pro_name!=null and pro_name!=''">
                 pro_name = #{pro_name},
            </if>
            <if test="pro_id!=null and pro_id!=''">
                 pro_id = #{pro_id},
            </if>
            nourish_id = #{nourish_id},
        </set>
        where id = #{id}
    </update>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不染心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值