java - 物化 View 上的 "Missing table"

标签 java hibernate postgresql jpa materialized-views

我有以下实体:

@Entity
@Table(name = "full_address")
public class FullAddress {

  @Id
  @Column(name = "guid")
  private String id;

  @Column(name = "address")
  private String address;

  //getters and setters omitted
}

另外我创建物化 View 如下:

CREATE TABLE address_table (
  -- address fields,
  aoid VARCHAR(36),
  CONSTRAINT address_pk PRIMARY KEY (aoid)
);
CREATE MATERIALIZED VIEW full_address AS
  SELECT buildFullAddressById(addrobj.aoid) AS address, addrobj.aoid AS guid FROM address_table AS addrobj;

-- buildFullAddressById is an sql function which is not important here

当我启动 Tomcat 应用程序时,我总是得到

org.hibernate.HibernateException: Missing table: full_address

为什么会这样?如何解决?

UPD:看起来像是 hibernate 中的错误:https://hibernate.atlassian.net/browse/HHH-9602

最佳答案

过去几天我遇到了同样的错误。作为this answer说过,可以在 persistence.xml 中禁用 hibernate.hbm2ddl.auto 属性,但如果您的项目正在快速开发,这不是一个好主意。

TL;DR: 将属性 hibernate.hbm2dll.extra_physical_table_types 设置为 MATERIALIZED VIEW

或将 -Dhibernate.hbm2dll.extra_physical_table_types="MATERIALIZED VIEW" 添加到 VM 选项。但最好将此类选项添加到配置文件中。


现在,我们正在使用 PostgreSQL 9.6 和 Hibernate 5.2.12.Final。不知何故,所有物化 View 验证均失败,但出现以下异常:

Caused by: org.hibernate.tool.schema.spi.SchemaManagementException: Schema-validation: missing table [our_project_schema.mv_one_of_views]

所有成功通过验证的实体都是简单的表或 View 。

这似乎是通用数据库的默认行为。在来源 here79-81 行,他们只添加了这些类型:

final List<String> tableTypesList = new ArrayList<>();
tableTypesList.add( "TABLE" );
tableTypesList.add( "VIEW" );

85-87 行告诉我们可以用自定义值扩展这些硬编码值:

if ( extraPhysicalTableTypes != null ) {
    Collections.addAll( tableTypesList, extraPhysicalTableTypes );
}

56 行,它被声明为 private String[] extraPhysicalTableTypes;, 在 71-77 行上,这个数组中添加了更多值:

if ( !"".equals( extraPhysycalTableTypesConfig.trim() ) ) {
    this.extraPhysicalTableTypes = StringHelper.splitTrimmingTokens(
        ",;",
        extraPhysycalTableTypesConfig,
        false
    );
}

它们来自 66-70 行,在键 EXTRA_PHYSICAL_TABLE_TYPES 下编码为字符串,默认值为空:

final String extraPhysycalTableTypesConfig = configService.getSetting(
    AvailableSettings.EXTRA_PHYSICAL_TABLE_TYPES,
    StandardConverters.STRING,
    ""
);

here 1545 行是该键的声明:

/**
 * Identifies a comma-separate list of values to specify extra table types,
 * other than the default "TABLE" value, to recognize as defining a physical table
 * by schema update, creation and validation.
 *
 * @since 5.0
 */
String EXTRA_PHYSICAL_TABLE_TYPES = "hibernate.hbm2dll.extra_physical_table_types";

因此,添加此属性将向 tableTypesList 添加另一个条目,用于过滤数据库中的许多其他实体,例如序列、索引、临时表等,它们的名称可能类似于你的物化 View 。

这就是我的 persistence.xml 的样子,如果您有兴趣的话:

<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://xmlns.jcp.org/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd"
             version="2.1">
    <persistence-unit name="project-pu">
        <jta-data-source>java:jboss/datasources/project-pu</jta-data-source>
        <properties>
            <property name="hibernate.dialect" value="org.hibernate.spatial.dialect.postgis.PostgisPG95Dialect"/>
            <property name="hibernate.hbm2ddl.auto" value="validate"/>
            <property name="hibernate.hbm2dll.extra_physical_table_types" value="MATERIALIZED VIEW"/>
            <property name="hibernate.show_sql" value="false"/>
            <property name="hibernate.format_sql" value="false"/>
            <property name="hibernate.use_sql_comments" value="false"/>
            <property name="hibernate.connection.url" value="jdbc:postgresql://localhost:5432/mgt"/>
            <property name="hibernate.connection.driver_class" value="org.postgresql.Driver"/>
        </properties>
    </persistence-unit>
</persistence>

附言我知道这是一个非常古老的帖子,但我为这个问题奋斗了几天。我没有找到答案,所以我决定把它放在互联网上的某个地方。而这个地方变成了这里。 :)

关于java - 物化 View 上的 "Missing table",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32625210/

相关文章:

java - 无法读取文件的最后一行,未进入循环

java - 如何在 JMeter 中测试异步回调?

java - ManyToMany 关系上的 PostgreSQL 约束违规错误,但应存在外键

postgresql - 具有编辑距离的组

django - 如果第二个表中存在过滤行,则注释 django 查询

postgresql - Postgres : Getting a total related count based on a condition from a related table

java - Unicode block : get alphabet of every language [Java]

java - 如何使用 JPA 1.0 构建 JPQL 查询从多个表中获取数据以克服惰性初始化?

java - Spring Hibernate FetchType LazyInitializationException 即使不调用关联时

java - 如何管理休息服务中的 session ?