2

使用Spring Data JDBC我希望将内部变量“inner”映射到外部表中的 varchar 列,而不是映射到自己的表。这可能吗?

public class Outer {
    @Id
    private String id;
    private Inner inner;
}

...

public class Inner {
   private String value;
}

...

public OuterRepository implements CrudRepository<Outer, String> {}

这是我的上下文配置:

@Configuration
@EnableJdbcRepositories
public class Config extends JdbcConfiguration {

    @Bean
    protected JdbcCustomConversions jdbcCustomConversions() {
        return new JdbcCustomConversions(asList(StringToInner.INSTANCE, InnerToString.INSTANCE));
    }

    @WritingConverter
    enum InnerToString implements Converter<Inner, String> {

        INSTANCE;

        @Override
        public String convert(Inner source) {
            return source.getValue();
        }
    }

    @ReadingConverter
    enum StringToInner implements  Converter<String, Inner> {

        INSTANCE;

        @Override
        public Inner convert(String source) {
            return new Inner(source);
        }
    }
}
4

2 回答 2

5

是的,这是可能的。您需要提供往返Inner的转换器String

在您的应用程序上下文配置中注册一个 bean jdbcCustomConversions

@Bean
CustomConversions jdbcCustomConversions() {
    return new JdbcCustomConversions(asList(InnerToString.INSTANCE, StringToInner.INSTANCE));
}

定义引用的转换器如下:

@WritingConverter
enum InnerToString implements Converter<Inner, String> {

    INSTANCE;

    @Override
    public String convert(Inner inner) {

        return inner == null ? null : inner.value;
    }
}

@ReadingConverter
enum StringToInner implements Converter<String, Inner> {

    INSTANCE;

    @Override
    public Inner convert(String source) {

        Inner inner = new inner();
        inner.value = source;
        return inner;
    }
}

转换器不必是枚举,但只要转换器没有参数化,就有多个实例是没有意义的。

注释@WritingConverter@ReadingConverter很重要,因为它们控制在写入数据库或从数据库读取时是否使用转换器。

请注意,这适用于存储在单个列中的类。尚不支持映射到列列表的正确嵌入实体。请参阅DATAJDBC-111

于 2018-11-14T08:51:57.390 回答
0

根据此文档,不可能在实体中使用内部类。

实体类要求一个可移植的 JPA 实体类:

应该是顶级类(即不是嵌套/内部类)。应该有一个公共或受保护的无参数构造函数。不能是最终的,也不能有最终的方法或最终的实例变量。

https://www.objectdb.com/java/jpa/entity/types

但是您可以检查@Embeddable 注释,这里是示例 https://www.callicoder.com/hibernate-spring-boot-jpa-embeddable-demo/ https://springframework.guru/embedded-jpa-entities-under-spring -启动和休眠命名/

于 2018-11-13T14:24:09.330 回答