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

网上网站怎么做互联网创业项目推荐

网上网站怎么做,互联网创业项目推荐,wordpress两边有空白,企业应用app文章目录 案例场景存在问题解决方案一解决方案二继续延伸 案例场景 很简单的工作场景,需要将数据库某个表的字段设置为null或者空字符串,使用mybatis-plus的update语句,如下: order.setPassCode(null);reservationOrderManger.up…

文章目录

  • 案例场景
  • 存在问题
  • 解决方案一
  • 解决方案二
  • 继续延伸

请添加图片描述

案例场景

很简单的工作场景,需要将数据库某个表的字段设置为null或者空字符串,使用mybatis-plus的update语句,如下:

	order.setPassCode(null);reservationOrderManger.updateById(order);

很自然的认为会更新成功,然后bug已经悄然而来,发现并没有更新成功,why??

存在问题

虽然我们的建表语句并没有对该字段进行非空限制,现在仅仅是希望把它更新为null,结果不成功。检查一下JavaBean,乍一看好像也没啥问题,其实Mybatis-Plus有一个更新策略FieldStrategy,默认是DEFAULT,在更新字段的时候,如果字段的值为null,就不会拼接到sql语句中,问题就出在这,因此我们需要手动调整更新策略。

@Data
public class XXXEntity{/*** 门禁通行码.*/@TableField(value = "pass_code")private String passCode;
}CREATE TABLE public.reservation_order (id uuid NOT NULL, -- 主键pass_code varchar(50) NULL, -- 通行码CONSTRAINT reservation_order_pkey PRIMARY KEY (id)
);

解决方案一

public class XXXEntity{/*** 门禁通行码.*/@TableField(value = "pass_code", updateStrategy = FieldStrategy.IGNORED)private String passCode;
}

五大策略

public enum FieldStrategy {// 不管有没有有设置属性,所有的字段都会设置到insert语句中,如果没设置值会更新为null IGNORED,// 也是默认策略,也就是忽略null的字段,不忽略""NOT_NULL,// 为null,为空串的忽略,就是如果设置值为null,“”,不会插入数据库NOT_EMPTY,// 同NOT_NULLDEFAULT,// 一经插入 永不更新 (etc:createTime)NEVER;private FieldStrategy() {}
}

解决方案二

设置全局的field-strategy(默认追随全局配置)
mybatis-plus:globalConfig:dbConfig:update-strategy: ignored
这样做是全局性配置,会对所有的字段都忽略判断,如果一些字段不想要修改,但是传值的时候没有传递过来,就会被更新为null,可能会影响其他业务数据的正确性。

继续延伸

在mybatis-plus中,不仅仅有更新策略,还有插入策略、查询策略,默认也是如果字段值为空不进行插入、查询,当然也可以自定义不同策略

public @interface TableField {String value() default "";boolean exist() default true;String condition() default "";String update() default "";FieldStrategy insertStrategy() default FieldStrategy.DEFAULT;FieldStrategy updateStrategy() default FieldStrategy.DEFAULT;FieldStrategy whereStrategy() default FieldStrategy.DEFAULT;
}// 使用方法
mybatis-plus:globalConfig:dbConfig:logicDeleteValue: "11"logicNotDeleteValue: "1"logicDeleteField: "model_status"update-strategy: ignoredwhere-strategy: ignoredinsert-strategy: ignored// 使用方法
@TableName("reservation_order")
public class XXXEntity {/*** 门禁通行码.*/@TableField(value = "pass_code", updateStrategy = FieldStrategy.IGNORED, insertStrategy = FieldStrategy.IGNORED, whereStrategy = FieldStrategy.IGNORED)private String passCode;
}
http://www.yayakq.cn/news/282925/

相关文章:

  • 手机网站建设的代码php空间放两个网站
  • 北京有做网站的吗wordpress安卓显示图片
  • 陕西网站建设推广公司wordpress弹窗网页
  • 免备案手机网站专门做考研的网站
  • 广州建网站白云区手机app制作官网
  • 宁波建设网站的公司如何做电商网站首页
  • 河池做网站wordpress安装插件出现api
  • 提供网站制作价格推广平台的句子
  • 网站建设设计大作业我所了解的网页制作软件
  • 做网站要收订金吗哈尔滨建设工程批前公示
  • 关于企业网站建设的请示iis 二级网站 发布
  • 赌求网站开发wordpress谷歌字体更换
  • 网站集约化建设规划网站所有权变更
  • 扬中零壹网站建设比尤果网做的好的网站
  • 网站怎么制作成二维码wordpress自媒体博客模板
  • 怎么看网站是谁家做的wordpress 防攻击插件
  • 设计网站合集的网站集团网站设计专业团队
  • 龙岗建设企业网站wordpress 发布文章主动推送百度
  • linode wordpress建站wordpress官方正式版
  • 百度手机管家宁波核心关键词seo收费
  • 珠海营销营网站建设网页设计排版布局
  • 黑龙江期刊网站制作酒泉建设局造价官网站
  • 七里河微信网站建设广州代运营公司有哪些
  • 网站建设策划书5000字聊城网站案例
  • 网站建设推广报价单微信公众平台注册要钱吗
  • wordpress网站怎么设置关键词js 网站怎么做中英文
  • 网站建设都用那些软件盐城企业网站制作
  • 百度网站建设多少钱建设网站地图
  • psd素材免费下载网站怎样自创广告网站
  • 婚恋网站策划专业餐饮网站建设