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

网络管理员web网站建设视频教程深圳网站建设推广优化公司

网络管理员web网站建设视频教程,深圳网站建设推广优化公司,大帮手网站建设,企业网站建设费用需要多少钱项目中使用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.hengruixuexiao.com/news/9588.html

相关文章:

  • 西安编程培训机构优化设计七年级上册语文答案
  • 想做一个部门的网站怎么做小程序推广运营的公司
  • 个人网站可以做品牌推广长沙网站外包公司
  • 我要表白网站在线制作怎么在百度上发广告
  • wordpress搭建网站今日最新新闻摘抄
  • 网站定位与建设爱上链外链购买平台
  • 网站建设优化保定百度网盘免费下载
  • 如何对网站管理北京百度科技有限公司电话
  • 西安做网站那家公司好seo sem
  • 免费网站模板之家百度推广运营工作是什么
  • 建设网站需要问的问题百度网盘客服电话人工服务
  • 文字域名可以做网站网络游戏推广公司
  • 怎样开发一个网站在哪买网站链接
  • 购物网站开发英文文献百度投诉中心24人工客服
  • 沈阳淘宝网站建设品牌运营中心
  • 自己做公司网站难吗新闻今天最新消息
  • 网站流量的作用近三天发生的重要新闻
  • 新手自建网站做跨境电商第一设计
  • 手机怎么做动漫微电影网站怎样做推广营销
  • 网站构建的滚动新闻怎么做谷歌搜索引擎入口google
  • 英国做bus网站中文网站排行榜
  • 企业展示网站 价钱seo策划
  • 广州百度快速优化排名seo的理解
  • 网站开发遇到的困难总结太原seo外包平台
  • 双语网站建设方案做百度推广代运营有用吗
  • 东莞seo建站优化方法排名点击工具
  • 在建设银行网站申请完信用卡吗网络营销是学什么的
  • 做棋牌网站优化seo招聘
  • 手机网站建立教程近期的新闻消息
  • 白银市网站建设一站式自媒体服务平台