当尝试将 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) 我有下表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)
我需要帮助使用标准构建器将上述查询转换为规范。