当前位置: 首页 > news >正文

如网站性质为公司 请以企业备案门户网站做

如网站性质为公司 请以企业备案,门户网站做,网站作业代做,企业公司如何做网站目录 前言1. 基本语法2. Demo3. 实际例子 前言 对于Java专栏:Java专栏 对于Mybatis的相关知识可看我之前的文章:Mybatis从入门到精通(全) 对于其余Java框架可看我之前的文章:java框架 零基础从入门到精通的学习路线 附…

目录

  • 前言
  • 1. 基本语法
  • 2. Demo
  • 3. 实际例子

前言

对于Java专栏:Java专栏
对于Mybatis的相关知识可看我之前的文章:Mybatis从入门到精通(全)
对于其余Java框架可看我之前的文章:java框架 零基础从入门到精通的学习路线 附开源项目面经等(超全)

对于上述Mybatis中曾有讲过foreach标签!此篇博客对其标签进行拓展

1. 基本语法

MyBatis中的<foreach>标签是用于迭代集合或数组的元素,生成对应的SQL片段,以便在动态SQL中使用。

该标签通常用于循环处理参数集合,生成多个相同的SQL片段,以实现批量操作或动态条件查询。

其基本的语法如下:

<foreach collection="collectionName" item="itemName" index="indexName" open="(" close=")" separator=",">#{itemName}
</foreach>

对应的属性如下:(只有collection和item是必选,其他都是可选参数)

  • collection: 指定要迭代的集合或数组的属性名,表示传入的参数的数据类型。
    该属性是必须指定的,用于指定要进行foreach操作的对象。
  • item: 指定在迭代过程中每个元素的别名,表示本次迭代获取的元素。
    若collection为List、Set或者数组,则表示其中的元素;
    若collection为map,则代表key-value的value。
    该参数是必选的。
  • index: 指定在迭代过程中每个元素的索引,仅对集合有效。
    在遍历List时,index表示元素的索引;在遍历Map时,index表示Map的key。该参数是可选的。
  • open: 指定迭代开始时的字符串,最常用的是左括弧'('
    MyBatis会将该字符拼接到整体的SQL语句之前,并且只拼接一次。该参数是可选的。
  • close: 指定迭代结束时的字符串,最常用的是右括弧')'
    MyBatis会将该字符拼接到整体的SQL语句之后。该参数是可选的。
  • separator: 指定每次迭代之间的分隔符。
    在SQL语句中,用于分隔不同元素的值。例如,1,2,3之间的,。该参数是可选的。

2. Demo

下面是一个简单的例子,假设有一个包含多个用户ID的集合,我们想要生成一个SQL语句查询这些用户:

<select id="selectUsersByIds" resultType="User">SELECT * FROM usersWHERE id IN<foreach collection="userIds" item="userId" open="(" close=")" separator=",">#{userId}</foreach>
</select>

在这个例子中,userIds是一个包含用户ID的集合,<foreach>标签会生成类似于IN (id1, id2, id3)的SQL片段。

另外,如果使用MyBatis的动态SQL功能,可以在<if>标签内使用<foreach>,以根据条件动态生成SQL片段,以下是一个例子,假设有一个条件查询的场景,根据用户选择的角色列表进行查询:

<select id="selectUsersByRoles" resultType="User">SELECT * FROM users<where><if test="roles != null and roles.size > 0">AND id IN<foreach collection="roles" item="role" open="(" close=")" separator=",">#{role}</foreach></if></where>
</select>

在这个例子中,selectUsersByRoles是一个动态SQL查询,它根据用户传入的roles参数动态生成SQL条件。

  • 如果roles不为空且包含元素,那么<if>标签内的内容会生效,生成类似于AND id IN (role1, role2, role3)的SQL片段。
  • 如果roles为空或不包含元素,该条件会被忽略,从而生成不包含AND的SQL语句。

在实际应用中,这种动态SQL的使用可以根据不同的业务需求动态构建查询条件,使SQL语句更加灵活和可复用。

3. 实际例子

结合实战中的例子,讲解更加透彻

  • 批量插入,即列表中有多个元素,代码示例:
<insert id="saveForList" parameterType="java.util.List">INSERT INTO E_DEVICE_TEMP_ALARM_HIST(DEVICE_NAME, BATTERY_TEMP, SEND_TO_DRIVER, CREATE_TIME, UPDATE_TIME, SENDER, SUGGESTION)<foreach collection="temperatureAlarmHistList" item="temperatureAlarmHist" separator="union all" open="(" close=")">SELECT#{temperatureAlarmHist.deviceName, jdbcType=VARCHAR},#{temperatureAlarmHist.batteryTemp, jdbcType=VARCHAR},#{temperatureAlarmHist.sendToDriver, jdbcType=INTEGER},#{temperatureAlarmHist.createTime, jdbcType=DATE},#{temperatureAlarmHist.updateTime, jdbcType=DATE},#{temperatureAlarmHist.sender, jdbcType=VARCHAR},#{temperatureAlarmHist.suggestion, jdbcType=VARCHAR}FROM DUAL</foreach>
</insert>
  • 动态SQL语句,更新语句也同理:
<update id="removeRuleDetailByRuleId"  >update equipment_change_shifts_rule_detail set is_deleted = 1 where rule_id IN<foreach collection="ids" item="id" index="index" open="(" separator="," close=")">#{id}</foreach>
</update>
  • 结合if语句,且参数位置可以随意:
<select id="trees" resultMap="treeNodeResultMap">select id, parent_id, equipment_name as title, id as 'value', id as 'key',location from equipment_architecture where is_deleted = 0<if test="tenantId!=null">and tenant_id = #{tenantId}</if>and id in<foreach close=")" collection="ids" item="listItem" open="(" separator=",">#{listItem}</foreach>
</select>
http://www.yayakq.cn/news/956628/

相关文章:

  • 海珠做网站公注册深圳公司流程和费用
  • 网站开发培训流程专业恶意点击软件
  • 网站内容策划方案网页培训
  • 企业门户网站需求文档德国设计网站大全
  • 手机网站qq代码wordpress设置网站关键字
  • 网站页脚景区网站建设方案 费用
  • 网站设计师要求wordpress 电商 插件
  • 网站内页seo查询网站建设 会计科目
  • 新媒体 网站建设 影视重庆做网站做得好的公司
  • 泰安 网站建设公司网络工程师是青春饭吗
  • 有做销售产品的网站微信小程序与网站连接
  • 佛山网站设计案例酒厂网站源码
  • 怎么把网站扒下来wordpress 文章 相册
  • 做网站和开发app有什么不同wordpress 变更中文
  • 网站首页开发设计有什么网站推荐
  • 静态页面网站站标代码写进到静态页面了 怎么不显示呢?挂甲寺网站建设
  • 设计公司网站图公司企业网站维护
  • cydia软件源网站开发企业vi设计的作用与意义
  • 四川网站建设设计公司排名打开qq邮箱进入wordpress
  • 怎么利用网站上的图片营销网站制作需要多少钱
  • 免费视频素材网站昆明抖音推广公司
  • 广州网站建设o2o网站源码多少钱
  • 亿图安卓系统优化大师
  • 谷歌网站的设计原则农村建设自己的网站
  • 深圳商城网站开发国外企业合作的网站
  • 男女做暖暖不要钱的试看网站竞品网站分析
  • 建设手机网站多少钱app开发主流技术
  • 免费建视频网站企业汽车网站建设
  • 建站系统社区想注册个网站做短租房投资多少钱
  • 闽侯县住房和城乡建设网站百度一下官网首页网址