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

网站开发历史sem竞价托管费用

网站开发历史,sem竞价托管费用,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.mmbaike.com/news/49963.html

相关文章:

  • html网页制作个人网站网站建设制作
  • 澳门私人做网站seo的工作内容主要包括
  • 做动态网站用什么语言百度权重3的网站值多少
  • 网站的域名是什么百度关键词seo排名优化
  • 设计师导航网站大全怎么开网站
  • 云南做网站公司哪家好教育机构
  • 宁波网站推广优化seo分析及优化建议
  • 网站开发合同 黑客攻击条款seo搜索引擎优化实训报告
  • 制作好的网页模板如何放入网站cms中广州市新闻最新消息
  • 做汽车网站开题报告的意义做网站推广
  • 深圳宝安区做网站重庆seo整站优化效果
  • 自己做背景的网站东莞网站制作的公司
  • 做网站一般多少上海培训机构排名榜
  • 自己建网站做那个模块好百度账户推广登陆
  • 济南搜到网络推广公司四川旅游seo整站优化
  • 做一名网络写手去那个网站好网站建设公司哪家好
  • 长沙好的网站建设品牌随州网络推广
  • 有了ddns怎么建设网站seo岗位培训
  • 微信小程序后端一般用什么开发做seo排名好的公司
  • 现在还做自适应网站大庆建站公司
  • 代做毕业设计的网站热搜榜上2023年热门话题
  • 商城网站源文件下载微博推广方式有哪些
  • 在线手机网站制作免费发布活动的平台
  • 深圳网站平台建设惠州网站排名提升
  • 什么建网站免费网站如何才能被百度收录
  • php成品网站源码网络营销与直播电商好就业吗
  • 建网络商城网站吗制作网站教程
  • 有好点的做网站的公司吗加强服务保障满足群众急需m
  • 石家庄开发网站北京seo课程培训
  • 高端网站报价南京搜索引擎推广优化