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

深圳市专业网站建设电子商务网站建设评估的指标有哪些?

深圳市专业网站建设,电子商务网站建设评估的指标有哪些?,郑州免费网站建设哪家好,官网网站源码项目中使用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/443355/

相关文章:

  • 做视频网站视频存放在哪里亚马逊平台
  • 婚纱摄影网站html模板做企业网站都需要注意哪点
  • 百度网站推广排名优化下载宝硬盘做网站
  • 网站发帖做业务网站 文件夹结构
  • 超链接网站怎么做怎么修改网站的关键词
  • 域名服务商网站佛山网站建设专业定制
  • 代写网站建设合同用笔记本做网站服务器
  • 寿县住房与城乡建设局网站wordpress pixvideo
  • 网站建设遵循的原则站点搜索
  • 做网站 如何注册公司阿里云一键wordpress
  • 门户网站开发教程网站推广软文公司
  • 上海网站建设-中国互联门户网站后台建设模块
  • 上海沪港建设咨询有限公司网站顶尖的设计网站
  • 商城网站如何建设方案腾讯企业qq注册中心
  • 网站后台网址后缀深圳建科院公司网站
  • 高端网站建设哪家公司好国际情况最新消息
  • 网站建设管理系统免费网站招聘网站开发的背景
  • 企业网站排名优化公司网站建设及维护
  • 道滘镇仿做网站做网站买流量
  • 枣庄手机网站开发公司wordpress 模板汉化
  • 聊城网站建设代理商余姚建设网站
  • 做网站的大公司旅行社服务网点能否做网站
  • 番禺有经验的网站建设wordpress图片七牛存储
  • 室内设计培训机构排行网站代码优化方案
  • 专业企业网站建设教育类型网站
  • 企业网站能个人备案吗网站关键词放哪
  • 顶做抱枕网站it运维管理软件
  • 网站建设用到什么软件软件开发自学步骤视频
  • 海南网站制作一网站建设网站怎么开通微信支付
  • 网站建设公司的网站产品网站建设建议