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

保定网站制作推广平台网站怎么做

保定网站制作推广,平台网站怎么做,如何自学网站建设,专业网站推广软件MyBatis 动态 SQL 标签if 标签where 标签trim 标签choose 、when 、otherwise 标签foreach 标签附 动态 SQL 标签 MyBatis 动态 SQL 标签,是一组预定义的标签,用于构建动态的 SQL 语句,允许在 SQL 语句中使用条件、循环和迭代等逻辑。通过使…

MyBatis

  • 动态 SQL 标签
    • if 标签
    • where 标签
    • trim 标签
    • choose 、when 、otherwise 标签
    • foreach 标签

在这里插入图片描述

动态 SQL 标签

MyBatis 动态 SQL 标签,是一组预定义的标签,用于构建动态的 SQL 语句,允许在 SQL 语句中使用条件、循环和迭代等逻辑。通过使用动态 SQL 标签,开发者可以根据不同的条件和参数生成不同的 SQL 语句,实现更加灵活的数据访问操作。但是,需要谨慎处理 SQL 注入问题,确保所有的输入都经过正确的验证和转义处理,以防止安全漏洞的产生。

常用的动态 SQL 标签

  • if 标签:根据条件判断是否包含 SQL 语句片段
  • where 标签:根据条件控制 SQL 语句的查询条件部分
  • trim 标签:根据条件去除或添加字符串前后的特定字符
  • choose 、when 、otherwise 标签:根据条件选择不同的 SQL 语句片段
  • foreach 标签:在 SQL 语句中迭代一个集合

简单示例:
首先,创建一张数据表 dynamic_sql_object
表结构如图:
在这里插入图片描述
表信息如图:
在这里插入图片描述

接着,创建与数据表一一映射的实体类 DynamicSqlObject

package cn.edu.MyBatisDemo.model;public class DynamicSqlObject {private int id;private String name;private String grade;private int age;private String phone;public DynamicSqlObject() {super();}public DynamicSqlObject(int id, String name, String grade, int age, String phone) {this.id = id;this.name = name;this.grade = grade;this.age = age;this.phone = phone;}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getGrade() {return grade;}public void setGrade(String grade) {this.grade = grade;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public String getPhone() {return phone;}public void setPhone(String phone) {this.phone = phone;}@Overridepublic String toString() {return "DynamicSqlObject{" +"id=" + id +", name='" + name + '\'' +", grade='" + grade + '\'' +", age=" + age +", phone='" + phone + '\'' +'}';}
}

然后,创建一个接口 DynamicSqlObjectMap ,声明获取指定用户信息的方法。同时,创建映射文件 DynamicSqlObjectMap.xml 实现接口方法

package cn.edu.MyBatisDemo.mapper;import cn.edu.MyBatisDemo.model.DynamicSqlObject;
import org.apache.ibatis.annotations.Param;public interface DynamicSqlObjectMap {//加上 @Param() 注解防止抛出异常---ReflectionException: There is no getter for property named 'xxx'public DynamicSqlObject getObject(@Param("name") String name,@Param("phone") String phone); // 获取指定用户信息
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd"><!-- 每个标签示例中再补充 -->
<mapper namespace="cn.edu.MyBatisDemo.mapper.DynamicSqlObjectMap"><select id="getObject" resultType="dynamicSqlObject" >SELECT `id`,`name`,`grade`,`age`,`phone` FROM `dynamic_sql_object`</select>
</mapper>

最后,测试结果,对每个标签进行简单示例

if 标签

在上面的示例中,select 标签定义了一个名为 getObject 的查询语句,其结果类型为 DynamicSqlObject 。
在 SQL 语句中,首先可以使用 WHERE 1=1 来构建一个通用的条件,然后使用 if 标签根据不同的条件来添加额外的限制条件。在 if 标签中,使用 test 属性来判断条件是否满足,若满足则执行该标签内的 SQL 语句片段;若不满足则不执行。
在这里插入图片描述

结果如图:
传递的参数值为 {name: “曹操”, phone: null} ,则生成的 SQL 语句为

SELECT `id`,`name`,`grade`,`age`,`phone` FROM `dynamic_sql_object` WHERE 1=1 AND `name`= '曹操'

在这里插入图片描述

where 标签

在 where 标签中,可以根据不同的条件动态生成不同的 WHERE 子句,从而灵活地执行数据库查询操作。在 where 标签内使用 if 标签来添加条件语句。
在这里插入图片描述

结果如图:
传递的参数值为 {name: “曹操”, phone: “13625987401”} ,则生成的 SQL 语句为

SELECT `id`,`name`,`grade`,`age`,`phone` FROM `dynamic_sql_object` WHERE `name`= '曹操' AND `phone`= '13625987401'

在这里插入图片描述

:where 标签只可以去掉第一个条件语句中前面的 AND 或 OR

trim 标签

在 trim 标签中,可以在动态 SQL 语句中去除前缀或后缀,也可以在 select 、update 或 insert 标签中使用。

trim 标签属性

  • prefix:添加前缀
  • prefixOverrides:去除前缀
  • suffix:添加后缀
  • suffixOverrides:去除后缀

在这里插入图片描述

结果如图:
传递的参数值为 {name: “曹操”, phone: “13625987401”} ,则生成的 SQL 语句为

SELECT `id`,`name`,`grade`,`age`,`phone` FROM `dynamic_sql_object` WHERE `name`= '曹操' AND `phone`= '13625987401'

在这里插入图片描述

choose 、when 、otherwise 标签

choose、when、otherwise 标签是一组标签,配合使用。choose 标签包含多个 when 标签和一个 otherwise 标签。在 when 标签中,使用 test 属性来判断条件是否满足,若满足则执行该标签内的 SQL 语句片段;若没有任何条件满足,则 otherwise 标签内的 SQL 语句片段作为默认的语句片段执行。
在这里插入图片描述

结果如图:
传递的参数值为 {name: “曹操”, phone: “15489723601”} ,则生成的 SQL 语句为

SELECT `id`,`name`,`grade`,`age`,`phone` FROM `dynamic_sql_object` WHERE `name`= '曹操'

在这里插入图片描述


条件选择:在 when、otherwise 标签中,当多个条件都满足时,只选择最前面的一条 SQL 语句片段执行(从上往下的顺序)
条件判断:在 if 标签中,当多个条件都满足时,所有满足条件的 SQL 语句片段都会执行

foreach 标签

foreach 标签适用于遍历集合、批量操作的情况。

foreach 标签属性

  • collection:指定的集合
  • item:指定集合的每一个值的迭代变量
  • separator:在生成的 SQL 语句中,每个元素之间的分隔符
  • open:在生成的 SQL 语句中,需要在 IN 子句或 BETWEEN 子句的前面添加的字符串
  • close:在生成的 SQL 语句中,需要在 IN 子句或 BETWEEN 子句的后面添加的字符串

foreach 标签示例中还需要再声明一个批量获取指定用户信息的方法。同时,在映射文件 DynamicSqlObjectMap.xml 中实现该接口方法
在这里插入图片描述

<select id="getObjectByIds" resultType="dynamicSqlObject" >SELECT `id`,`name`,`grade`,`age`,`phone` FROM `dynamic_sql_object` WHERE `id` IN<foreach collection="ids" item="id" separator="," open="(" close=")" >#{id}</foreach>
</select>

结果如图:
传递的参数值为 {20230830,20230832} ,则生成的 SQL 语句为

SELECT `id`,`name`,`grade`,`age`,`phone` FROM `dynamic_sql_object` WHERE `id` IN(20230830,20230832)

在这里插入图片描述

set 标签用在更新的操作上,在 SQL 语句中动态生成多个 SET 子句。在 set 标签内使用多个 if 标签来判断哪些属性需要更新或不做处理。
在这里插入图片描述

sql 标签用于定义可重用的 SQL 片段,方便在不同的地方复用。include 标签用于将另一个映射文件中定义的 SQL 片段引入到当前映射文件中。这两个标签配合使用,可以减少重复的 SQL 代码,提高代码的可维护性和可读性。
在这里插入图片描述

bind 标签用于动态地生成 SQL 语句的绑定变量。

http://www.yayakq.cn/news/559222/

相关文章:

  • jquery做的装修网站高端网站设计百家号
  • 唐山网站网站建设三站合一的网站怎么做教程
  • 有域名了怎么建设网站陕西网站备案代理
  • 网站发多少篇文章开始做外链做网站好的网站建设公司
  • 网站制作的评价指标中国500强企业排名表
  • 百度网站提交入口网址网站建设的专业术语
  • 上海市建设网站wordpress标签
  • 网站建设 官自适应网站建设服务哪家好
  • 湖南网站备案网站 用php asp源码 比较好
  • 网站建设全网推广小程序龙岩网红阙佩琪
  • 建设银行住房公积网站山西省建设执业资格注册中心网站
  • aspnet做网站视频教程玉林博白网站建设
  • 快速网站开发框架建造免费网站
  • 长春专业做网站的公司排名学校网站建设情况说明
  • 团购网站优化自助建立网站
  • 网页设计做网站宜宾移动网站建设
  • 网站常用英文网站整体色调
  • 网站开发的重点难点Wordpress修改主题菜单样式
  • 网站专门做冻品的国外推广渠道有哪些方式
  • 网站标题怎么隔开网络会议
  • 长宁区网站制网站开发中应注意哪些问题
  • 网站首页生成静态页面wordpress毕设
  • 中国移动网站官网sem竞价培训
  • 大岭山仿做网站大庆开发网站公司
  • 旅游网站建设与网页设计意义网站建设怎么记账
  • 外贸产品推广网站谷歌官网网址
  • 网站建设为什么这么贵规划案例网站
  • 网站模板 英文个人社保缴费基数是什么意思
  • 合肥网站建设维护自然堂官方网站建设
  • 成品网站源码是1688吗营销策划方案怎么写?