-2

私のアプリケーションはこの例外をスローします。バックエンドとしてJavaDBを使用しており、JPAを使用しています

内部例外:java.sql.SQLException:テーブル/ビュー'POCKETMONEY'は既にスキーマ'APP'に存在します。エラーコード:30000呼び出し:CREATE TABLE APP.POCKETMONEY(ID INTEGER NOT NULL、DateofSpending DATE、DESCRIPTION VARCHAR(255)、AMOUNT INTEGER、PRIMARY KEY(ID))クエリ:DataModifyQuery()

内部例外:java.sql.SQLException:テーブル/ビュー'SEQUENCE'はスキーマ'ADMIN'にすでに存在します。エラーコード:30000呼び出し:CREATE TABLE SEQUENCE(SEQ_NAME VARCHAR(50)NOT NULL、SEQ_COUNT DECIMAL、PRIMARY KEY(SEQ_NAME))クエリ:DataModifyQuery()

これが私のJPAコードです

/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package mymoney;

import java.io.Serializable;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;

/**
 *
 * @author sugan
 */
@Entity
@Table(schema = "APP")
public class pocketMoney implements Serializable {

    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue(strategy=GenerationType.TABLE)
    private int id;
    @Temporal(TemporalType.DATE)
    @Column(name = "DateofSpending")
    private Date dos;
    private String description;
    private int amount;

    public int getAmount() {
        return amount;
    }

    public void setAmount(int amount) {
        this.amount = amount;
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    public Date getDos() {
        return dos;
    }

    public void setDos(Date dos) {
        this.dos = dos;
    }

    public int getId() {
        return id;
    }

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

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (int) id;
        return hash;
    }

    @Override
    public boolean equals(Object object) {
        // TODO: Warning - this method won't work in the case the id fields are not set
        if (!(object instanceof pocketMoney)) {
            return false;
        }
        pocketMoney other = (pocketMoney) object;
        if (this.id != other.id) {
            return false;
        }
        return true;
    }

    @Override
    public String toString() {
        return "mymoney.pocketMoney[id=" + id + "]";
    }
}

Persistence.xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">
  <persistence-unit name="myMoneyPU" transaction-type="RESOURCE_LOCAL">
    <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
    <class>mymoney.pocketMoney</class>
    <properties>
      <property name="eclipselink.jdbc.password" value="adminadmin"/>
      <property name="eclipselink.jdbc.user" value="admin"/>
      <property name="eclipselink.jdbc.driver" value="org.apache.derby.jdbc.EmbeddedDriver"/>
      <property name="eclipselink.jdbc.url" value="jdbc:derby:pocketmoney;create=true"/>
      <property name="eclipselink.ddl-generation" value="drop-and-create-tables"/>
    </properties>
  </persistence-unit>
</persistence>
4

1 に答える 1

2

使用しているJPAプロバイダーが何であれ、マッピングに対応するデータベースオブジェクトを生成およびエクスポートするように構成されていると思われます...そしてそれらはすでに存在しています。

構成、JPA プロバイダー、正確なメッセージ (EclipseLink は警告 AFAIK などのメッセージをログに記録します) に応じて、これは単なる正常または「構成ミス」である可能性があります。

詳細が必要な場合は、使用しているプロバイダーをお知らせくださいpersistence.xml

更新:疑わしいように、EclipseLink を使用しており、これらのメッセージは「正常」です (メッセージ IIRC をよく見ると、警告としてログに記録されます)。

于 2010-09-01T08:59:41.397 に答える