小编Ram*_*amu的帖子

杰克逊序列化不包括双值 0.0

当尝试将 double 值映射/设置为 0.0 时,ObjectMapper 将其视为等效于 null,从而在比较相等性时排除。

我有以下测试用例:

import com.fasterxml.jackson.annotation.JsonInclude.Include;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
import java.util.Map;
import lombok.Getter;
import lombok.Setter;
import net.javacrumbs.jsonunit.JsonAssert;
import org.junit.Test;

public class ValidJson {

@Getter
@Setter
static class Temp {
  Double dblValue;
  Integer intVal;
  boolean valid = false;
}

@Test
public void validJson() throws Exception {
    ObjectMapper objectMapper = new ObjectMapper();
    objectMapper.setSerializationInclusion(Include.NON_NULL);
    objectMapper.setSerializationInclusion(Include.NON_DEFAULT);

    String json = "{\"dblValue\":0.0}";
    Temp generatedObj = objectMapper.readValue(json, Temp.class);
    Map<?, ?> originalJsonMap = objectMapper.readValue(json, Map.class);

    JsonNode generatedObjMap = objectMapper.valueToTree(generatedObj);
    JsonNode originalObjMap = objectMapper.valueToTree(originalJsonMap); …
Run Code Online (Sandbox Code Playgroud)

java json jackson-databind

5
推荐指数
1
解决办法
1062
查看次数

如何使用 spring 数据规范查询 jsonb 列?

我有下表temp_tbl (postgres):

    ID(int)     NAME(TEXT)    LINKS(jsonb)
    --------    ----------    -------------------
    1           Name1         ["1","23","3", "32]
    2           Name2         ["11","3","31", "2]
    3           Name3         ["21","13","3", "12]
Run Code Online (Sandbox Code Playgroud)

现在,我的本机查询获取具有值为“3”的“LINKS”的行是:

    select * from temp_tbl where links @> '["3"]'
Run Code Online (Sandbox Code Playgroud)

返回第 2 行和第 3 行。

我想使用 org.springframework.data.jpa.domain.Specification 实现这个查询

我已经实现了类似下面的内容,其中 jsonb 列不是数组,但使用jsonb_extract_path_text具有键值 json 。但是上面的列只存储数组中的值。

我的实体类。

    ID(int)     NAME(TEXT)    LINKS(jsonb)
    --------    ----------    -------------------
    1           Name1         ["1","23","3", "32]
    2           Name2         ["11","3","31", "2]
    3           Name3         ["21","13","3", "12]
Run Code Online (Sandbox Code Playgroud)

我需要帮助使用标准构建器将上述查询转换为规范。

criteria spring-data

5
推荐指数
1
解决办法
427
查看次数

标签 统计

criteria ×1

jackson-databind ×1

java ×1

json ×1

spring-data ×1