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

做网站如何赚流量钱福州百度推广开户

做网站如何赚流量钱,福州百度推广开户,哈尔滨最新政策,3d打印网站开发【BUG 记录】MyBatis-Plus 处理枚举字段和JSON字段 一、枚举字段(mysql环境已测、postgresql环境已测)1.1 场景1.2 定义枚举常量1.3 配置枚举处理器1.4 测试 二、JSON字段(mysql环境已测)2.1 导包2.2 使用对象接受2.3 测试 三、JS…

【BUG 记录】MyBatis-Plus 处理枚举字段和JSON字段

  • 一、枚举字段(mysql环境已测、postgresql环境已测)
    • 1.1 场景
    • 1.2 定义枚举常量
    • 1.3 配置枚举处理器
    • 1.4 测试
  • 二、JSON字段(mysql环境已测)
    • 2.1 导包
    • 2.2 使用对象接受
    • 2.3 测试
  • 三、JSON 字段 (postgresql环境 已测)
    • 3.1 postgresql 数据库中的字段类型设置为 jsonb
    • 3.2 创建实体类
    • 3.3 创建 jsonb 类型处理器
      • 3.3.1 方式一
      • 3.3.2 方式二
    • 3.4 测试

在这里插入图片描述

一、枚举字段(mysql环境已测、postgresql环境已测)

1.1 场景


User 实体类中有一个枚举字段(GenderEnum):

@Data
@TableName("test_user")
public class UserEntity {@TableId(value = "id", type = IdType.AUTO)private Integer id;private String name;private Integer age;private GenderEnum gender;private String address;private String phone;
}

  像这种字段我们一般会定义一个枚举,做业务判断的时候就可以直接基于枚举做比较。但是我们数据库采用的是 int 类型,对应的 PO 也是Integer。因此业务操作时必须手动把枚举与 Integer 转换,非常麻烦。因此,Mybatis Plus提供了一个处理枚举的类型转换器,可以帮我们把枚举类型与数据库类型自动转换。

1.2 定义枚举常量


  首先,我们为用户表中的这个状态字段定义一个枚举常量:

@Getter
public enum GenderEnum{WOMAN(0,"女"),MAN(1, "男");@EnumValueprivate final Integer code;@JsonValueprivate final String desc;GenderEnum(Integer code,String desc){this.code = code;this.desc = desc;}
}

要让 Mybatis Plus处理枚举与数据库类型自动转换,我们必须告诉 Mybatis Plus,枚举中的哪个字段的值作为数据库值。Mybatis Plus 提供了 @EnumValue 注解来标记枚举属性

并且,在GenderEnum枚举中通过@JsonValue注解标记 JSON 序列化时展示的字段是 desc

1.3 配置枚举处理器


  在application.yml 文件中添加以下配置,以开启枚举处理器的功能:

mybatis-plus:configuration:default-enum-type-handler: com.baomidou.mybatisplus.core.handlers.MybatisEnumTypeHandler # 枚举处理器

1.4 测试


  例如,根据id查询某个用户:
  此时,查询出的User类的 status 字段会是枚举类型。
1703574125196.png

二、JSON字段(mysql环境已测)

2.1 导包


<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.79</version>
</dependency>

2.2 使用对象接受


@Data
@TableName(value= "test_user" ,autoResultMap = true)
public class UserEntity {@TableId(value = "id", type = IdType.AUTO)private Integer id;private String name;private Integer age;private GenderEnum gender;@TableField(typeHandler = FastjsonTypeHandler.class)private JSONObject address;private String phone;
}

注意:

  1. 添加 autoResultMap = true,开启自动映射
  2. 添加 @TableField(typeHandler = FastjsonTypeHandler.class),JSON处理器
  3. 字段类型修改为 JSONObject

2.3 测试


image.png

image.png

三、JSON 字段 (postgresql环境 已测)

3.1 postgresql 数据库中的字段类型设置为 jsonb


image.png

3.2 创建实体类


  • 在实体类上加上 @TableName(value = "表名", autoResultMap = true)
  • jsonb属性上加上 @TableField(value = "字段", typeHandler = JsonbTypeHandler.class)

JsonbTypeHandler 这个类在下面创建

@Data
@TableName(value= "test_user" ,autoResultMap = true)
public class UserEntity {@TableId(value = "id", type = IdType.AUTO)private Integer id;private String name;private Integer age;private GenderEnum gender;@TableField(value = "address", typeHandler = JsonbTypeHandler.class)private Object address;private String phone;
}

3.3 创建 jsonb 类型处理器

3.3.1 方式一


import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature;
import com.baomidou.mybatisplus.extension.handlers.AbstractJsonTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedJdbcTypes;
import org.apache.ibatis.type.MappedTypes;
import org.postgresql.util.PGobject;import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Objects;@MappedTypes({Object.class})
@MappedJdbcTypes({JdbcType.VARCHAR})
public class JsonbTypeHandler extends AbstractJsonTypeHandler<Object> {private static final PGobject jsonObject = new PGobject();private final Class<?> type;public JsonbTypeHandler(Class<?> type) {this.type = type;}/*** 重写设置参数* @param ps* @param i* @param parameter* @param jdbcType* @throws SQLException*/@Overridepublic void setNonNullParameter(PreparedStatement ps, int i, Object parameter, JdbcType jdbcType) throws SQLException {if (ps != null) {jsonObject.setType("jsonb");jsonObject.setValue(JSON.toJSONString(parameter));ps.setObject(i, jsonObject);}}/*** 根据列名,获取可以为空的结果* @param rs* @param columnName* @return* @throws SQLException*/@Overridepublic Object getNullableResult(ResultSet rs, String columnName) throws SQLException {Object v = rs.getObject(columnName);return toFill(v);}/*** 根据列索引,获取可以为空的结果* @param rs* @param columnIndex* @return* @throws SQLException*/@Overridepublic Object getNullableResult(ResultSet rs, int columnIndex) throws SQLException {Object v = rs.getObject(columnIndex);return toFill(v);}@Overridepublic Object getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {Object v = cs.getObject(columnIndex);return toFill(v);}@Overrideprotected Object parse(String json) {return JSON.parseObject(json, this.type);}/*** 必须将 v 转成 PGObject 处理* @param v* @return*/private Object toFill(Object v) {if (v != null && v instanceof PGobject) {PGobject p = (PGobject) v;String pv = p.getValue();if (Objects.nonNull(pv) && ("jsonb".equals(p.getType()) || "json".equals(p.getType()))) {return parse(p.getValue());}}return v;}@Overrideprotected String toJson(Object obj) {return JSON.toJSONString(obj, SerializerFeature.WriteMapNullValue, SerializerFeature.WriteNullListAsEmpty, SerializerFeature.WriteNullStringAsEmpty);}
}

3.3.2 方式二


package com.xawl.webenum.handler;import com.alibaba.fastjson.JSON;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedTypes;
import org.postgresql.util.PGobject;import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;@MappedTypes({Object.class})
public class JsonbDataTypeHandler extends BaseTypeHandler<Object> {private static final PGobject jsonObject = new PGobject();@Overridepublic void setNonNullParameter(PreparedStatement preparedStatement, int i, Object o, JdbcType jdbcType) throws SQLException {if (preparedStatement != null) {jsonObject.setType("jsonb");jsonObject.setValue(JSON.toJSONString(o));preparedStatement.setObject(i, jsonObject);}}@Overridepublic Object getNullableResult(ResultSet resultSet, String s) throws SQLException {return JSON.parse(resultSet.getString(s));}@Overridepublic Object getNullableResult(ResultSet resultSet, int i) throws SQLException {return JSON.parse(resultSet.getString(i));}@Overridepublic Object getNullableResult(CallableStatement callableStatement, int i) throws SQLException {return JSON.parse(callableStatement.getString(i));}
}

3.4 测试


  1. 测试 save

image.png 插入成功
image.png

  1. 测试 get

image.png

http://www.mmbaike.com/news/32761.html

相关文章:

  • 国外网站搭建平台地推推广方案
  • 模版营销型网站怎么做seo优化交流
  • wordpress 国内最好主题厦门seo怎么做
  • 现在个人做网站或者app还有收益推广平台
  • sqlite做网站北京关键词快速排名
  • 个人网站怎么做 简历推动防控措施持续优化
  • 在线商城网站建设seo建设
  • 顺德网站建设成都网络营销
  • 如何在百度上找网站广州百度seo排名
  • 阿里巴巴网站建设方案免费发布产品的网站
  • 做网站月薪资多少钱做网销的一天都在干嘛
  • 网站推广昔年下拉google浏览器网页版
  • 企业网站建设遵循的原则微网站建站平台
  • 小型营销企业网站建设策划qq代刷网站推广
  • c 网站开发调试营销型网站制作
  • 深圳做手机网站多少钱50个市场营销经典案例
  • 凡科做的是网站吗怎样创建网站平台
  • 佛山网站建设哪家专业免费的关键词优化工具
  • 云服务器做网站视屏人力资源和社会保障部
  • 网站支付宝网上支付功能怎么做优化软件
  • 推广 电子商务网站建设一份完整的品牌策划方案
  • wordpress插件破解下载地址seo刷词
  • 做网站的排名seo关键词快速排名
  • 做目的旅游网站的搜索引擎排名竞价
  • 自动化营销网站建设成都官网seo服务
  • 网站怎样续费全球搜怎么样
  • 大连开发区招聘网站怎样推广公司的网站
  • 门户网站建设方案目录域名查询ip网站
  • 网站搜索优化怎么做百度小说风云榜排名
  • 福建城市建设厅网站抖音指数