Mybatis标签SQL

<sql></sql>标签:抽取可重复使用的SQL片段,方便后面引用

<!-- 
        抽取可重复使用的SQL片段,方便后面引用
        1.SQL抽取:经常将要查询的列名,或者插入用的列名抽取出来方便引用
        2.include来引用已经抽取的SQL
        3.include还可以自定义一些property,SQL标签内部就能使用自定
            取值的正确方式:${property}
             #{不能使用这种方式}
     -->
    <sql id="insertColumn">
        deptno,dname,loc<!-- ,${column1} -->
    </sql>
 

批量保存使用: 

<insert id="addDepts" databaseId="oracle"
    parameterType="com.jadeon.mybatis.bean.Dept">
    <!-- Oracle:批量保存方法1  -->
        <!-- <foreach collection="depts" item="dept" open="begin" close="end;">
               insert into dept(deptno,dname,loc)
                   values (dept_seq.nextval,#{dept.dname},#{dept.loc});
        </foreach> -->
    <!-- Oracle:批量保存方法2  -->
    insert into dept(
        <include refid="insertColumn">
            <!-- <property name="column1" value="abc"/> -->
        </include>
        
    )
        select dept_seq.nextval,dname,loc from(
            <foreach collection="depts" item="dept" separator="union" >
                       select #{dept.dname} dname ,#{dept.loc} loc from dual
            </foreach>
        )
    </insert>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值