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

专门做网站的公司与外包公司磁力狗在线

专门做网站的公司与外包公司,磁力狗在线,佛山市手机网站建设企业,网络工作室源码目录 一、<if>标签 二、<trim>标签 三、<where>标签 四、<set>标签 五、<foreach>标签 一、<if>标签 当我们在某个平台提交某些信息时&#xff0c;可能都会遇到这样的问题&#xff0c;有些信息是必填信息&#xff0c;有些信息是非必…

目录

一、<if>标签

二、<trim>标签

三、<where>标签

四、<set>标签

五、<foreach>标签


一、<if>标签

当我们在某个平台提交某些信息时,可能都会遇到这样的问题,有些信息是必填信息,有些信息是非必填信息,例如,使用CSDN发布博客时:

那么程序猿在不确定某个字段是否会被用户传入时,该如何拼接SQL呢?这就需要使用<if>标签来判断某个字段是否被用户输入

代码示例:

    <insert id="insertUser">insert into userinfo(username, password<if test="photo != null">,photo</if>) values(#{username}, #{password}<if test="photo != null">,#{photo}</if>)</insert>

单元测试代码:

    @Testvoid insertUser() {UserInfo userInfo = new UserInfo();userInfo.setUsername("apple");userInfo.setPassword("123");userInfo.setPhoto(null);int ret = userMapper.insertUser(userInfo);System.out.println(ret);}

代码执行结果:

可以看到,photo为空时,最终构造的SQL语句并没有拼接photo字段。 

注意: 

(1) <if>标签必须包含test属性,如果test属性中的内容为true,则执行<if>标签语句中的内容;如果为false,则不执行,此时数据库中该字段的值为默认值。

(2) <if>标签中判断的字段必须是可以为null的字段,如果判断的字段不允许为null,程序会在执行期间报错。


二、<trim>标签

如果所有字段都是非必填信息,那么就需要使用<trim>标签结合<if>标签,对多个字段都采取动态生成的方式。

代码示例:

    <insert id="insertUser2">insert into userinfo<trim prefix="(" suffix=")" suffixOverrides=","><if test="username!=null">username,</if><if test="password!=null">password,</if><if test="photo!=null">photo,</if></trim><trim prefix="values (" suffix=")" suffixOverrides=","><if test="username!=null">#{username},</if><if test="password!=null">#{password},</if><if test="photo!=null">#{photo},</if></trim></insert>

<trim>标签中的4个属性所表示的含义:

prefix:表示整个语句块以prefix的值作为前缀;

suffix:表示整个语句块以suffix的值作为后缀;

prefixOverrides:表示整个语句块要去掉的前缀;

suffixOverrides:表示整个语句块要去掉的后缀。

三、<where>标签

<where>标签需要配合<if>标签来使用,用来接收动态参数进行查询数据库操作。

代码示例:

    <select id="selectUsers" resultType="com.example.demo.model.UserInfo">select * from userinfo<where><if test="username != null">username=#{username}</if><if test="password != null">and password=#{password}</if></where></select>

注意:

(1) <where>标签会删除语句块的前缀内容(and);

(2) <where>标签中的字段如果都为null,那么就不会生成where关键字。

上述示例代码也可以使用<trim prefix="where" prefixOverrides="and">替换。 

四、<set>标签

<set>标签可以配合<if>标签,根据用户传入的参数来修改数据,用法和<where>标签类似。

代码示例:

    <update id="updateUser">update userinfo<set><if test="username != null">username=#{username},</if><if test="password != null">password=#{password},</if><if test="photo != null">photo=#{photo},</if></set>where id=#{id};</update>

注意:

(1) <set>标签会删除语句块的后缀内容(,);

(2) <set>标签中的字段如果都为null,那么就不会生成set关键字。

上述示例代码也可以使用<trim prefix="set" suffixOverrides=",">替换。

五、<foreach>标签

<foreach>标签用于对集合进行遍历,例如根据多个文章id删除文章。

代码示例:

    <delete id="deleteUsers">delete from userinfo where id in<foreach collection="list" open="(" close=")" item="id" separator=",">#{id}</foreach></delete>

<foreach>标签中的5个必要属性:

collection:集合的名称(对应方法中的集合的参数名);

item:遍历集合时,集合中每个对象的名字;

separator:每次遍历之间以什么字符串间隔;

open:语句块的前缀内容;

close:语句块的后缀内容。

用一段伪代码来解释上述5个属性:

http://www.hkea.cn/news/259036/

相关文章:

  • 建设银行etc官方网站搜索引擎优化的七个步骤
  • 做网站需要花钱吗海南百度推广运营中心
  • 做的网站显示图片很慢百度运营公司
  • 青州哪里做网站公司推广渠道
  • 网站面包屑导航怎么做的网推接单平台有哪些
  • 宜昌网站建设兼职百度关键词排名软件
  • 如何让百度快照找到自己的网站营销策划方案ppt模板
  • php网站超市广告软文是什么意思
  • b2c跨境电商宣城网站seo
  • 网站建设一流公司免费网站开发平台
  • 网站开发模式名词外贸谷歌优化
  • 网站素材 下载产品推广渠道
  • 网站后台维护怎么做seo专员工资一般多少
  • 中国网站推广黄页名录微商推广哪家好
  • 哈尔滨网站开发电话电商培训基地
  • 如何用php数据库做网站搜索seo优化托管
  • 中国城乡建设部人力网站首页优化落实疫情防控
  • 做网站到底能不能赚钱网络优化工程师前景
  • 乌镇网站建设标书百度站长工具域名查询
  • 制作公司网站价格腾讯广告代理商加盟
  • 大学生活动网站开发文案苏州seo门户网
  • 阿里云认证网站建设题库seo助理
  • 凤岗网站仿做靠谱seo外包定制
  • xampp安装wordpress说明徐州seo外包
  • 啥网站都能看的浏览器下载百度收录查询工具
  • 福田附近公司做网站建设哪家效益快奶糖 seo 博客
  • 临沂免费自助建站模板品牌整合营销
  • iis做本地视频网站找客户资源的网站
  • 做调查用哪个网站网络推广有多少种方法
  • 开发一个交易网站多少钱在线工具