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

建筑网站新闻写那些好wordpress同步到微信

建筑网站新闻写那些好,wordpress同步到微信,西安有什么好玩的值得去的地方,十大行情软件免费下载安装项目中使用PostGresql数据库进行数据存储,表中某字段为Json类型,用于存储Json格式数据。PG数据库能够直接存储Json算是一大特色,很多特定情境下使用直接存储Json字段数据能够大量节省开发时间,提高后台数据查询和转换效率。 1、基…

项目中使用PostGresql数据库进行数据存储,表中某字段为Json类型,用于存储Json格式数据。PG数据库能够直接存储Json算是一大特色,很多特定情境下使用直接存储Json字段数据能够大量节省开发时间,提高后台数据查询和转换效率。

1、基础mysql类型与MyBatis数据进行交互

在这里插入图片描述
如果我们有一个JSONObject属性的字段需要与数据库中Json格式的数据进行交互,此时我们就需要自定义一个转换类,将数据库中json格式的对象映射为Java对象,也可以使用Mybatis对JSONObject对象进行映射,将其在数据库中以json格式保存。

2、Entity

import com.alibaba.fastjson.JSONObject;
import lombok.Data;@Data
public class UserDO {private Long id;private JSONObject userInfo;
}

3、导入fastjson包

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

4、编写JSONTypeHandler类

import com.fasterxml.jackson.databind.ObjectMapper;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;public class JsonTypeHandler<T> extends BaseTypeHandler<T> {private static final ObjectMapper mapper = new ObjectMapper();private Class<T> clazz;public JsonTypeHandler(Class<T> clazz) {if (clazz == null) throw new IllegalArgumentException("Type argument cannot be null");this.clazz = clazz;}@Overridepublic void setNonNullParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException {ps.setString(i, this.toJson(parameter));}@Overridepublic T getNullableResult(ResultSet rs, String columnName) throws SQLException {return this.toObject(rs.getString(columnName), clazz);}@Overridepublic T getNullableResult(ResultSet rs, int columnIndex) throws SQLException {return this.toObject(rs.getString(columnIndex), clazz);}@Overridepublic T getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {return this.toObject(cs.getString(columnIndex), clazz);}private String toJson(T object) {try {return mapper.writeValueAsString(object);} catch (Exception e) {throw new RuntimeException(e);}}private T toObject(String content, Class<?> clazz) {if (content != null && !content.isEmpty()) {try {return (T) mapper.readValue(content, clazz);} catch (Exception e) {throw new RuntimeException(e);}} else {return null;}}
}

5、在Mybatis映射中加入调用类并编写insert和select方法

<resultMap id="TestJsonMapper" type="com.huahua.dao.DO.TestJsonDO"><id column="id" jdbcType="BIGINT" property="id"/><result column="user_info" property="jsonObject" javaType="com.alibaba.fastjson.JSONObject" typeHandler="com.huahua.dao.jsonHandler.JsonTypeHandler"/>
</resultMap><insert id="insert" parameterType="com.huahua.dao.DO.UserDO">insert into `user` (`id`, `user_info`)values (#{id,jdbcType=BIGINT}, #{jsonObject,typeHandler=com.huahua.dao.jsonHandler.JsonTypeHandler});</insert><select id="insert">select  `id`, `user_info`from user</select >

测试发现:均能正确存储和查询Json格式数据

参考资料
Mybatis实现JsonObject对象与JSON之间交互
postgresql数据库存储json类型的列相关增删改操作(springboot+mybatis)及相关实体类、xml的配置

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

相关文章:

  • 下载建设网站c2c网站特点
  • 现在哪个网站做电商好学校网站如何建设方案
  • 网站建设中+网页代码google wordpress
  • 临沂 网站优化wordpress多个页面
  • 网站开发如何避开法律青州网站设计
  • 长沙做网站哪家公司好学网页设计需要什么基础
  • 江苏城乡建设职业学院网站建筑工程联系方式公开网
  • vs做网站怎么把网页改为自适应大小凡科app
  • 乐清做网站公司chatgpt网址
  • 做菠菜网站好赚吗天津网页模板建站
  • 怎样在公司的网站服务器上更新网站内容北京哪里能学做网站
  • 网站开发 明细网页制作wordpress模板下载
  • 开源项目网站怎么做 带视频c2c网站制作
  • 台州网站专业制作企业所得税怎么做账
  • 自己做网站语言包怎么做centos 7.2 wordpress
  • 建自己的零售网站政法队伍建设网站主要内容
  • 体育馆做网站公司做咩有D网站响网吧上不了
  • 能直接看的网站有哪些成都网站建设免费咨询
  • 乐清市网站建设设计电商素材网站
  • 如何自己搭建网站手机之家官方网
  • 东莞东城网站建设做网站选什么专业
  • 做汽车拆解视频网站网站建设优化重庆
  • 微软做网站的工具完整企业网站模板
  • 个人备案的网站内容手机免费网站
  • 广州网站设计上海公司注销流程步骤
  • 在百度里面做个网站怎么做网络营销的手段有哪些
  • 无锡市网站搭建wordpress导入数据库
  • 深圳教育 网站建设wordpress恢复网站
  • 做网站开发的公司销售代理网址在线
  • 在临沂做网站哈尔滨网站建设哪家有