国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

解決mybatis plus字段為null或空字符串無法保存到數據庫的問題

瀏覽:89日期:2023-10-19 18:27:07
背景

項目中集成了mybatis plus, 今天在做后臺的一個常規的增刪改查時,發現字段值為null時,這個字段不會被保存到數據庫

解決辦法

在字段上加上

@TableField(strategy = FieldStrategy.IGNORED)

strategy字段更新插入策略屬性說明:

IGNORED(0): “忽略判斷”, 所有字段都更新和插入

NOT_NULL(1): “非 NULL 判斷”, 只更新和插入非NULL值

NOT_EMPTY(2): “非空判斷”, 只更新和插入非NULL值且非空字符串

另外一種方式可全局配置,未親手實踐。

補充:Mybatis查詢數據部分字段顯示為null,怎么轉成空串('')

1、先定義一個handler,來把字段為null的轉成空串('')

2、在Mapper.xml中,把可能為空的字段,加上typeHandler屬性,指定處理的handler類的全路徑。

CustomStringTypeHandler.java

package com.wang.common.mybatis.handler;import org.apache.ibatis.executor.result.ResultMapException;import org.apache.ibatis.type.BaseTypeHandler;import org.apache.ibatis.type.JdbcType;import org.apache.ibatis.type.MappedJdbcTypes;import org.apache.ibatis.type.MappedTypes;import java.sql.CallableStatement;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;/** * @Name: CustomStringTypeHandler * @Desc: 自定義mybatis處理類,將null返回為空串(‘’) * @Author: Administrator * @Date: 2019-09-03 18:20 */@MappedTypes({String.class})@MappedJdbcTypes(JdbcType.VARCHAR)public class CustomStringTypeHandler extends BaseTypeHandler<String> { @Override public String getResult(ResultSet rs, String columnName) { String result; try { result = getNullableResult(rs, columnName); } catch (Exception e) { throw new ResultMapException('Error attempting to get column ’' + columnName + '’ from result set. Cause: ' + e, e); } return result; } @Override public void setNonNullParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType) throws SQLException { ps.setString(i, parameter); } @Override public String getNullableResult(ResultSet rs, String columnName) throws SQLException { return rs.getString(columnName) == null? '' : rs.getString(columnName); } @Override public String getNullableResult(ResultSet rs, int columnIndex) throws SQLException { return rs.getString(columnIndex) == null? '' : rs.getString(columnIndex); } @Override public String getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { return cs.getString(columnIndex) == null? '' : cs.getString(columnIndex); }}

Mapper.xml

<?xml version='1.0' encoding='UTF-8'?><!DOCTYPE mapper PUBLIC '-//mybatis.org//DTD Mapper 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='com.wang.sss.fw.mapper.BusinessTripMapper'> <resultMap type='com.wang.sss.fw.pojo.BusinessTrip'> <result column='REQUEST_ID' jdbcType='VARCHAR' property='requestId' /> <result column='JOB_NUMBER' jdbcType='VARCHAR' property='jobNumber' /> <result column='REQUEST_DATE' jdbcType='VARCHAR' property='requestDate' /> <result column='DEPARTMENT' jdbcType='VARCHAR' property='department' /> <result column='BUSINESS_DAYS' jdbcType='VARCHAR' property='businessDays'/> <result column='CFD' jdbcType='VARCHAR' property='cfd' /> <result column='MDD' jdbcType='VARCHAR' property='mdd' /> <result column='START_TIME' jdbcType='VARCHAR' property='startTime' /> <result column='END_TIME' jdbcType='VARCHAR' property='endTime' /> <result column='REASON' jdbcType='VARCHAR' property='reason' typeHandler='com.wang.common.mybatis.handler.CustomStringTypeHandler'/> <result column='REMARK' jdbcType='VARCHAR' property='remark' typeHandler='com.wang.common.mybatis.handler.CustomStringTypeHandler'/> </resultMap></mapper>

沒有加typeHandler屬性,處理之前的查詢結果:

BusinessTrip(requestId=11925, jobNumber=5721, requestDate=2019-05-06, department=57, businessDays=21, cfd=上海, mdd=南京, startTime=2019-05-06 13:36, endTime=2019-05-07 13:36, reason=null, remark=null)

增加typeHandler屬性,處理后的結果:(reason和remark字段都變成了空串)

BusinessTrip(requestId=11925, jobNumber=5721, requestDate=2019-05-06, department=57, businessDays=21, cfd=上海, mdd=南京, startTime=2019-05-06 13:36, endTime=2019-05-07 13:36, reason=, remark=)

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 免费一级毛片在线播放视频 | 伊人久久大香线焦综合四虎 | 久久久久久久久久综合情日本 | 一级视频在线免费观看 | 特黄日韩免费一区二区三区 | 美女被免费视频网站a国产 美女被免费网站视频软件 美女被免费网站在线软件 美女被免费网站在线视频软件 | 精品亚洲成a人片在线观看 精品亚洲成a人在线播放 | 三级亚洲 | 国产亚洲欧美ai在线看片 | 国产手机在线小视频免费观看 | 日韩在线手机看片免费看 | 日韩美女毛片 | 国产99久久九九精品免费 | 国产一级在线观看www色 | 毛片的网址| 91网在线 | 日韩欧美一区二区三区在线 | 日本www免费视频网站在线观看 | 亚洲免费一区 | 日本免费高清视频二区 | 日韩一级片在线观看 | 国产精品二区页在线播放 | 日韩精品中文字幕一区二区三区 | 久久机热综合久久国产 | 国产大臿蕉香蕉大视频 | 欧美xxxxx毛片 | 和日本免费不卡在线v | av av片在线看 | 久久综合日韩亚洲精品色 | 亚洲精品成人av在线 | 韩国一级永久免费观看网址 | 爽爽日本在线视频免费 | 亚洲视频网站在线观看 | 亚洲精品在线免费看 | 欧美一级毛片免费播放器 | 在线国产一区二区 | 欧美日一级 | 国产精品久久久久久久久久久久久久 | 久久美女精品国产精品亚洲 | 国内精自品线一区91 | 91久久在线 |