微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

不支持 Java、Azure Cosmos 查询“空”值

如何解决不支持 Java、Azure Cosmos 查询“空”值

我正在查询 java 中的 NULL 值(在 cosmos 文档数据库上)但它抛出错误,下面是语法:

import com.azure.cosmos.models.CosmosQueryRequestOptions;
import com.azure.spring.data.cosmos.core.generator.FindQuerySpecGenerator;
import com.azure.cosmos.models.sqlQuerySpec;
import com.azure.spring.data.cosmos.core.query.CosmosQuery;
import com.azure.spring.data.cosmos.core.query.Criteria;
import com.azure.spring.data.cosmos.core.query.CriteriaType;
import org.springframework.data.repository.query.parser.Part;
import java.util.Arrays;

Criteria criteria = Criteria.getInstance(CriteriaType.IS_EQUAL,"tripId",new ArrayList(Arrays.asList(null)),Part.IgnoreCaseType.NEVER);

CosmosQuery documentQuery = new CosmosQuery(criteria);
sqlQuerySpec sqlQuerySpec = new FindQuerySpecGenerator().generateCosmos(documentQuery);
    

这里是例外: 线程“main”中的异常 java.lang.NullPointerException 在 java.util.Objects.requireNonNull(Objects.java:203) 在 java.util.Arrays$ArrayList.(Arrays.java:3813) 在 java.util.Arrays.asList(Arrays.java:3800)

解决方法

解决方案:

ArrayList<Object> emptyList= new ArrayList<Object>();
Criteria criteria = Criteria.getInstance(CriteriaType.IS_NULL,"tripId",emptyList,Part.IgnoreCaseType.NEVER);
    
CosmosQuery documentQuery = new CosmosQuery(criteria);
SqlQuerySpec sqlQuerySpec = new FindQuerySpecGenerator().generateCosmos(documentQuery);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。