JDBCTemplate RowMapper 读取 postgres 中的 jsonb 列 table

JDBCTempalte RowMapper to read jsonb column in postgres table


我正在使用具有以下架构的 JDBCTemplate 阅读 Postgres table:

orderid|order_name|features|extra_features|

orderid: 整数
order_name: 文字
特征:josnb
extra_features: jsonb

订购 DTO:

public class Order{
  private Integer orderid;
  private String orderName;
  List<Features> features;
  List<ExtraFeatures> extraFeatures;
       ....

   getter & setter   
}

特征 DTO:

public class Features{
  private String featureName:
  private String featureValuel
}

现在,在执行 SELECT * FROM public.orders 查询时,我正在编写如下所示的 rowMapper: jdbcTemplate.query("SELECT * FROM public.orders", new OrderRowMapper())

RowMapper

public class OrderRowMapper implements RowMapper<Order>{
  @Override
  public Order mapRow(ResultSet rs, int rowNum) throws SQLException{
     Order order = new Order();
     order.setOrderid(rs.getInt("orderid"));
     order.setFeatures()// how to read jsonbcolumn?
  }
}

我可以设置除 jsonb 列之外的所有值,我不知道如何为此实现 RowMapper,请帮忙。


public class OrderRowMapper implements RowMapper<Order>{
  private ObjectMapper mapper = new ObjectMapper();

  @Override
  public Order mapRow(ResultSet rs, int rowNum) throws SQLException{

     List<Features> features = objectMapper
          .readValue(rs.getString("features"), 
                     new TypeReference<List<Features>>(){});
     Order order = new Order();
     order.setOrderid(rs.getInt("orderid"));
     order.setFeatures()// how to read jsonbcolumn?
  }
}