0

我有这个我想与 JPA 一起使用的数据库表

CREATE TABLE translations (
id  SERIAL NOT NULL, 
KEY VARCHAR(255), 
LANGUAGE VARCHAR(255), 
TRANSLATION VARCHAR(255)
)

我创建了这个实体:

@Entity
@Table(name = "translations")
public class TranslationTestEntitie extends AbstractEntityWithId {

    private static final long serialVersionUID = 2029240552230401080L;

    @Column(name = "id", insertable=false, updatable=false)
    private long id;
    @Column(name = "key", insertable=false, updatable=false)
    private String key;
    @Column(name = "language", insertable=false, updatable=false)

    private String language;
    @Column(name = "translation", insertable=false, updatable=false)
    private String translation;

    public TranslationTestEntitie() {
    }

    // Getters and setters
    public Long getId() {
        return id;
    }

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

    public String getKey() {
        return key;
    }

    public void setKey(String key) {
        this.key = key;
    }

    public String getLanguage() {
        return language;
    }

    public void setLanguage(String language) {
        this.language = language;
    }

    public String getTranslation() {
        return translation;
    }

    public void setTranslation(String translation) {
        this.translation = translation;
    }

}

当我尝试进行此查询时SELECT c FROM Translations c WHERE c.Id = 70

我收到这条消息The abstract schema type 'Translations' is unknown.

根据数据库表,这个实体是否正确。

PS这是我用来获取数据的代码:

public TData td;

    public class TData {

        private long id;
        private String key;
        private String language;
        private String translation;

        public TData() {
        };

        public TData(long id, String key, String language, String translation) {
            // super();
            this.id = id;
            this.key = key;
            this.language = language;
            this.translation = translation;
        }

        public long getId() {
            return id;
        }

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

        public String getKey() {
            return key;
        }

        public void setKey(String key) {
            this.key = key;
        }

        public String getLanguage() {
            return language;
        }

        public void setLanguage(String language) {
            this.language = language;
        }

        public String getTranslation() {
            return translation;
        }

        public void setTranslation(String translation) {
            this.translation = translation;
        }

    }

    public TData getDataObj() {
        return td;
    }

    @PostConstruct
    public void loadData() {

        td = new TData();

        String query = "SELECT c FROM Translations c WHERE c.id = 70";
        td = (TData) dao.jpqlQuerySingle(query);//(query);//jpqlQuery(query);

    }

但我仍然得到空对象。

4

2 回答 2

2

映射到您的数据库表的实体translations已命名TranslationTestEntitie

from TranslationTestEntitie c那么应该适合您的需求。

于 2013-03-20T10:29:26.750 回答
1

也许是因为你的表名不是Translationsbut translations

SELECT c FROM translations c WHERE c.id = 70

和小写的id。

于 2013-03-20T10:28:56.333 回答