位置: IT常识 - 正文

mybatis常用标签(refid、foreach、trim)(mybatis isnotempty标签)

编辑:rootadmin
mybatis常用标签(refid、foreach、trim) 1.问题来源

推荐整理分享mybatis常用标签(refid、foreach、trim)(mybatis isnotempty标签),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mybatis常用标签有哪些,mybatis常用标签有哪些,mybatisforeach标签,mybatisforeach标签,mybatis常用的标签,mybatisbind标签,mybatiswhen标签,mybatiswhen标签,内容如对您有帮助,希望把文章链接给更多的朋友!

在之前查询数据库的时候基本都是使用

select * from student;SELECT name, prod_price FROM products;

但是很多时候我们并不需要查询数据库中的全部字段,直接查全部字段会降低效率,同时很多字段的组合是经常被使用到的,每次都单独写出来很麻烦

2.Mybatis解决 对于上述问题,Mybatis的映射文件中为我们引入了<include refid="Base_Column_List" /> ,意思就是固定几个需要查询的字段,在sql语句中不需要写具体的字段了。具体使用如下:

<sql id="Base_Column_List"> id, username, password, email, phone, question, answer, role, create_time, update_time</sql><select id="selectByUsername" parameterType="java.lang.String" resultMap="BaseResultMap"> select <include refid="Base_Column_List" /> from mall_user where username = #{username,jdbcType=VARCHAR}</select>

2、mybatis动态sql中foreach标签的使用

foreach标签主要用于构建in条件,他可以在sql中对集合进行迭代。如下:

<delete id="deleteBatch"> delete from user where id in<foreach collection="array" item="id" index="index" open="("  close=")" separator=","> #{id} </foreach></delete>

我们假如说参数为----  int[] ids = {1,2,3,4,5}  ----那么打印之后的SQL如下:

delete form user where id in (1,2,3,4,5)释义: collection:collection属性的值有三个分别是list、array、map三种,分别对应的参数类型为:List、数组、map集合,我在上面传的参数为数组,所以值为array

item :表示在迭代过程中每一个元素的别名

index:表示在迭代过程中每次迭代到的位置(下标)

open :前缀

close:后缀

mybatis常用标签(refid、foreach、trim)(mybatis isnotempty标签)

separator:分隔符,表示迭代时每个元素之间以什么分隔

我们通常可以将之用到批量删除、添加等操作中。

相当于mysql里的游标!!!

3、mybatis动态sql中的trim标签的使用

trim标记是一个格式化的标记(format),可以完成set或者是where标记的功能,如下代码:

1、

select * from user<trim prefix="WHERE" prefix override="AND |OR"><if test="name != null and name.length()>0"> AND name= #{name}</if><if test="gender != null and gender.length()>0"> AND gender= #{gender}</if></trim>

假如说name和gender的值都不为null的话打印的SQL为:

select * from user where   #  name = 'xx' and gender = 'xx'

在红色# 标记的地方是不存在第一个and的,上面两个属性的意思如下:

prefix:前缀      

prefixoverride:去掉第一个and或者是or

2、

update user<trim prefix="set" suffix override="," suffix=" where id =#{id} "><if test="name != null and name.length()>0"> name=#{name} ,</if><if test="gender != null and gender.length()>0"> gender=#{gender} , </if></trim>

假如说name和gender的值都不为null的话打印的SQL为:

update user set name='xx' , gender='xx' #  whereid='x'

在红色标记的地方不存在逗号,而且自动加了一个set前缀和where后缀,上面三个属性的意义如下,其中prefix意义如上:

suffixoverride:去掉最后一个逗号(也可以是其他的标记,就像是上面前缀中的and一样)

suffix:后缀

本文链接地址:https://www.jiuchutong.com/zhishi/299686.html 转载请保留说明!

上一篇:【Android源码面试宝典】MMKV从使用到原理分析(二)(android界面源码)

下一篇:html+css+js制作LOL官网,web前端大作业(3个页面+模拟登录+链接)(js怎么制作)

  • 小规模纳税人做账要做增值税吗
  • 股东投资是所有者权益
  • 增值税附加税有没有滞纳金
  • 公司汽车上牌费入什么科目
  • 为什么生产车间地板是绿色的
  • 银行回单可以做收入吗
  • 设计服务类合同
  • 生产企业出口转内销增值税申报
  • 进项税加计扣除账务处理
  • 新企业需要结转增值税吗
  • 库存盘盈盘亏按进价还是售价
  • 现金支付借款如何认定
  • 采购折扣怎么结转成本?
  • 商城退换货
  • 关于固定资产的企业案例
  • 企业发生什么
  • 印花税的计税依据含税吗
  • 2017年7月后手撕发票还能报销吗?
  • 预缴企业所得税研发费用加计扣除
  • 分步法所分的成本计算步骤应是实际的生产步骤
  • 多次出库的商品最后一起结账的分录怎么写?
  • 增值税发票认证操作流程
  • mac可以制作win启动盘吗
  • php循环语句
  • 用公司资质应交什么费用
  • 应收账款包括哪些
  • 印度活根桥 (© dhritipurna/Shutterstock)
  • php获取上个月第一天
  • yii2组件的理解
  • 如何在vue项目中运行后端
  • 行人重识别map
  • 以股权抵债的会计分录
  • 未分配利润为负数怎么调整
  • 个人税收收入退税政策
  • 消防工程材料费用占比
  • 企业异地预交的税怎么算
  • ubuntu系统安装教程
  • mysql乱码产生原因
  • 离岸价的含义
  • 预付费卡开票
  • 子公司注销时的账务处理
  • 医疗服务增值税税率
  • 个税汇算要清缴么
  • 暂估入库跨年账务危险
  • 红冲以前年度的费用怎么做账
  • 房屋出租后转租缴纳房产税吗
  • 丁字账户例题及解析
  • 企业代扣代缴个税
  • 待抵扣进项税额分录
  • 带息票据为什么是贷财务费用
  • 总部结算什么意思
  • 会计人员基本信息表去哪找
  • 收到福利费的专用发票
  • mysql的拼接符号
  • 强行卸载系统应用
  • 苹果的mac系统
  • 电脑如何安装Anaconda
  • 新买的苹果电脑没有电
  • red hat7.6
  • centos6.0安装教程
  • win7主题服务未运行怎么办
  • WZor曝光Win10专业版升级教育版的密钥 无法激活
  • win7运行速度
  • win7的环境变量如何还原
  • linux查看系统配置内存大小
  • angularjs4
  • 关于jquery的事件冒泡,以下描述正确的是
  • unity控制组件开关
  • 电脑兼容ie
  • python爬取某人所有朋友圈
  • Android多个surface
  • 用js实现类的方法
  • 滴滴发票怎么查行程
  • 纳税信用d级企业保留几年
  • 企业所得税忘记交了怎么办
  • 税务系统领发票
  • 金华市税务
  • 2018年企业所得税
  • 设区市是哪里
  • 公司税务怎么查询缴款信息呢
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设