java - 更改 Naturald 参数名称后出错

标签 java database hibernate rename liquibase

我已经使用 liquibase 更改了 NaturalId 列名称(从“name”到“query_name”):

<changeSet id="rename_name_to_query_name">
    <preConditions onFail="CONTINUE">
        <columnExists tableName="pm_dbqueries" columnName="name" />
        <not>
            <columnExists tableName="pm_dbqueries" columnName="query_name" />
        </not>
    </preConditions>
    <renameColumn
        columnDataType="varchar(40)"
        newColumnName="query_name"
        oldColumnName="name"
        tableName="pm_dbqueries"/>
</changeSet>

它工作正常,名称已更改...我还用 java 更新了我的实体类:

@Entity
@Table( name = "pm_dbqueries", uniqueConstraints = { @UniqueConstraint(columnNames = "id"),
                                                      @UniqueConstraint(columnNames = "query_name") } )
@SequenceGenerator( name = "pm_dbqueries_seq", sequenceName = "pm_dbqueries_seq" )
public class DBQuery
{   
    @Id
    @GeneratedValue( strategy = GenerationType.AUTO, generator = "pm_dbqueries_seq" )
    @Column(name = "id", unique = true, nullable = false)
    private Long id;

    @NaturalId
    @Column(name = "query_name", unique = true, nullable = false, length = 40)
    private String queryName;

    @Column(name = "query", unique = false, nullable = false, length = 4000)
    private String query;

    public Long getId()
    {
        return id;
    }

    public void setId( Long id )
    {
        this.id = id;
    }

    public String getQueryName()
    {
        return queryName;
    }

    public void setQueryName( String queryName )
    {
        this.queryName = queryName;
    }

    public String getQuery()
    {
        return query;
    }

    public void setQuery( String query )
    {
        this.query = query;
    }
}

但问题是...当我尝试执行此操作时:

return (DBQuery) sessionFactory.getCurrentSession().byNaturalId(DBQuery.class).using( "query_name", name ).load();

出现错误:

org.hibernate.HibernateException: No value specified for natural-id property XXX.DBQuery#queryName
    at org.hibernate.event.spi.ResolveNaturalIdEvent.<init>(ResolveNaturalIdEvent.java:102)
    at org.hibernate.event.spi.ResolveNaturalIdEvent.<init>(ResolveNaturalIdEvent.java:52)
    at org.hibernate.internal.SessionImpl$BaseNaturalIdLoadAccessImpl.resolveNaturalId(SessionImpl.java:2466)
    at org.hibernate.internal.SessionImpl$NaturalIdLoadAccessImpl.load(SessionImpl.java:2581)

在这些更改之前它工作正常。有什么建议吗?

最佳答案

试试这个,因为您需要在此处使用属性名称而不是列名称。它工作得更早,因为两者之间没有区别(名称 == 名称)。

return (DBQuery) sessionFactory.getCurrentSession().byNaturalId(DBQuery.class).using( "queryName", name ).load();

关于java - 更改 Naturald 参数名称后出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50227773/

相关文章:

java - Hibernate Master Detail 级联插入

java - 将大部分对象保存在缓存/内存中而不是数据库中?

java - berkeley xml db作为java的嵌入式数据库

java - 在 Java Derby 中创建包含值的表

javascript - 尝试放置新项目时出现 DynamoDB InvalidParameterType 错误

Oracle 数据库中的 REGEXP 挫败感

java - App Engine - 云 SQL - java.sql.SQLException : This Connection is closed

java - DAO vs ORM( hibernate )模式

Java JApplet : Why aren't my components appearing on screen?

javax.naming.NoInitialContextException : Need to specify class name in environment or system property