java - 在 Spring Data 中为同一 QueryDSL 路径创建多个别名

标签 java spring spring-data spring-data-rest querydsl

我有一个通用的 Spring Data 存储库接口(interface),它扩展了 QuerydslBinderCustomizer,允许我自定义查询执行。我正在尝试扩展默认存储库实现中内置的基本相等测试,以便我可以使用 Spring Data REST 执行其他查询操作。例如:

GET /api/persons?name=Joe%20Smith  // This works by default
GET /api/persons?nameEndsWith=Smith  // This requires custom parameter binding.

我遇到的问题是我创建的实体路径的每个别名似乎都覆盖了前面的别名绑定(bind)。

@NoRepositoryBean
public interface BaseRepository<T, ID extends Serializable>
    extends PagingAndSortingRepository<T, ID>, QueryDslPredicateExecutor<T>, QuerydslBinderCustomizer { 

    @Override
    @SuppressWarnings("unchecked")
    default void customize(QuerydslBindings bindings, EntityPath entityPath){

        Class<T> model = entityPath.getType();
        Path<T> root = entityPath.getRoot();
        for (Field field: model.getDeclaredFields()){
            if (field.isSynthetic()) continue;
            Class<?> fieldType = field.getType();
            if (fieldType.isAssignableFrom(String.class)){
                // This binding works by itself, but not after the next one is added
                bindings.bind(Expressions.stringPath(root, field.getName()))
                        .as(field.getName()  + "EndsWith")
                        .first((path, value) -> {
                            return path.endsWith(value);
                        });
                // This binding overrides the previous one
                bindings.bind(Expressions.stringPath(root, field.getName()))
                        .as(field.getName()  + "StartsWith")
                        .first((path, value) -> {
                            return path.startsWith(value);
                        });
            }
        }
    }
}

是否可以为同一个字段创建多个别名?这可以通过通用方式完成吗?

最佳答案

您可以通过这种方式创建绑定(bind)到 QueryDSL 的 transient 属性:

@Transient
@QueryType(PropertyType.SIMPLE)
public String getNameEndsWith() {
    // Whatever code, even return null
}

如果您使用的是 QueryDSL 注解处理器,您将在元数据 Qxxx 类中看到“nameEndsWith”,因此您可以像绑定(bind)任何持久化属性一样绑定(bind)它,但无需持久化它。

关于java - 在 Spring Data 中为同一 QueryDSL 路径创建多个别名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41667317/

相关文章:

java - MVC注解 Spring MVC <mvc :annotation-driven/>

java - 应用程序级别的安全远程密码协议(protocol)

Java Spring data mongodb如何使用通配符?

java - OutputStream.write 仅在 Java 中写入字符串的一部分

java - spring hibernate .. H2 数据库 - 找不到模式

java - 如何使用 spring-jdbc 在 Oracle 存储过程中使用 IN OUT 参数?

java - 在 Spring MVC 的 servlet 映射中,如何映射 url 模式目录的根目录?

mysql - Spring Data JPA(Hibernate)未将列创建为自动增量

java - ElasticSearch RestHighLevelClient 抛出 java.io.IOException : Connection reset by peer

java - Java如何对数据集进行排序