błąd po dodaniu relacji @OneToMany i @ManyToOne

0

Powstaje mi błąd po dodaniu relacji między dwoma encjami. Posiadam dwie encje aukcja i druga kategoria.
Aukcja ma kategorię i między kategorią a aukcją istnieje relacja jeden do wiele.
W testowej aplikacji dodałem pierwsze zapisy dotyczące relacji czyli, deklarację @OneToMany do Kategoria i @ManyToOne do Aukcja.
W tym momencie aplikacja wywołuje błędy przy odwołaniu się do encji tu przykład błędu dodania rekordu aukcji

 


Aukcja


package encje;

import java.io.Serializable;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Date;
import javax.persistence.Basic;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.persistence.Version;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;
import javax.xml.bind.annotation.XmlRootElement;

/**
 *
 * @author oracle
 */
@Entity
@Table(name = "Aukcja")
@XmlRootElement
@NamedQueries({
    @NamedQuery(name = "Aukcja.findAll", query = "SELECT a FROM Aukcja a"),
    @NamedQuery(name = "Aukcja.findByIdAukcji", query = "SELECT a FROM Aukcja a WHERE a.idAukcji = :idAukcji"),
    @NamedQuery(name = "Aukcja.findByIdKategoria", query = "SELECT a FROM Aukcja a WHERE a.idKategoria = :idKategoria"),
    @NamedQuery(name = "Aukcja.findByTytul", query = "SELECT a FROM Aukcja a WHERE a.tytul = :tytul"),
    @NamedQuery(name = "Aukcja.findByOpis", query = "SELECT a FROM Aukcja a WHERE a.opis = :opis"),
    @NamedQuery(name = "Aukcja.findByAktualnaCena", query = "SELECT a FROM Aukcja a WHERE a.aktualnaCena = :aktualnaCena"),
    @NamedQuery(name = "Aukcja.findByDataRozpoczecia", query = "SELECT a FROM Aukcja a WHERE a.dataRozpoczecia = :dataRozpoczecia"),
    @NamedQuery(name = "Aukcja.findByDataZakonczenia", query = "SELECT a FROM Aukcja a WHERE a.dataZakonczenia = :dataZakonczenia"),
    @NamedQuery(name = "Aukcja.findByIdUzytkownikaSprzedajacego", query = "SELECT a FROM Aukcja a WHERE a.idUzytkownikaSprzedajacego = :idUzytkownikaSprzedajacego"),
    @NamedQuery(name = "Aukcja.findByIdUzytkownikaWygrywajacego", query = "SELECT a FROM Aukcja a WHERE a.idUzytkownikaWygrywajacego = :idUzytkownikaWygrywajacego"),
    @NamedQuery(name = "Aukcja.findByIdUzytkownikaWygrywajacegoWygrane", query = "SELECT a FROM Aukcja a WHERE a.idUzytkownikaWygrywajacego = :idUzytkownikaWygrywajacego AND a.dataZakonczenia < CURRENT_TIMESTAMP ORDER BY a.dataZakonczenia DESC"),
    @NamedQuery(name = "Aukcja.findByIdUzytkownikaSprzedajacegoWystawione", query = "SELECT a FROM Aukcja a WHERE a.idUzytkownikaSprzedajacego = :idUzytkownikaSprzedajacego AND a.dataZakonczenia > CURRENT_TIMESTAMP ORDER BY a.dataZakonczenia ASC")
})
public class Aukcja implements Serializable {
    private static final long serialVersionUID = 1L;

    
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id_aukcji")
    private Integer  idAukcji;
    
    @Version
    private Integer wersja;
    
    @Basic(optional = false)
    @NotNull
    @Column(name = "id_kategoria")
    private int idKategoria;
    
    
    
    @ManyToOne(optional = false)
    @JoinColumn(name = "kategoria", referencedColumnName = "idKategoria")
    private Kategoria kategoria;
            
            
    @Basic(optional = false)
    @NotNull
    @Size(min = 1, max = 45)
    @Column(name = "tytul")
    private String tytul;
    @Size(max = 200)
    @Column(name = "opis")
    private String opis;
    // @Max(value=?)  @Min(value=?)//if you know range of your decimal fields consider using these annotations to enforce field validation
    @Basic(optional = false)
    @NotNull
    @Column(name = "aktualna_cena")
    private BigDecimal aktualnaCena;
    @Basic(optional = false)
    @NotNull
    @Column(name = "data_rozpoczecia")
    @Temporal(TemporalType.TIMESTAMP)
    private Date dataRozpoczecia;
    @Column(name = "data_zakonczenia")
    @Temporal(TemporalType.TIMESTAMP)
    private Date dataZakonczenia;
    @Basic(optional = false)
    @NotNull
    @Column(name = "id_uzytkownika_sprzedajacego")
    private int idUzytkownikaSprzedajacego;
    @Column(name = "id_uzytkownika_wygrywajacego")
    private Integer idUzytkownikaWygrywajacego;
    @Size(min = 1, max = 15)
    @Column(name = "status_aukcji")
    private String  statusAukcji;

    public Aukcja() {
    }

    public Aukcja(Integer idAukcji) {
        this.idAukcji = idAukcji;
    }

    public Aukcja(Integer idAukcji, int idKategoria, String tytul, BigDecimal aktualnaCena, Date dataRozpoczecia, int idUzytkownikaSprzedajacego, String statusAukcji) {
        this.idAukcji = idAukcji;
        this.idKategoria = idKategoria;
        this.tytul = tytul;
        this.aktualnaCena = aktualnaCena;
        this.dataRozpoczecia = dataRozpoczecia;
        this.idUzytkownikaSprzedajacego = idUzytkownikaSprzedajacego;
        this.statusAukcji = statusAukcji;
    }

    public Integer getIdAukcji() {
        return idAukcji;
    }

  /*  public void setIdAukcji(Integer idAukcji) {
        this.idAukcji = idAukcji;
    } */

    public int getIdKategoria() {
        return idKategoria;
    }

    public void setIdKategoria(int idKategoria) {
        this.idKategoria = idKategoria;
    }

    public String getTytul() {
        return tytul;
    }

    public void setTytul(String tytul) {
        this.tytul = tytul;
    }

    public String getOpis() {
        return opis;
    }

    public void setOpis(String opis) {
        this.opis = opis;
    }

    public BigDecimal getAktualnaCena() {
        return aktualnaCena;
    }

    public void setAktualnaCena(BigDecimal aktualnaCena) {
        this.aktualnaCena = aktualnaCena;
    }

    public Date getDataRozpoczecia() {
        return dataRozpoczecia;
    }

    public void setDataRozpoczecia(Date dataRozpoczecia) {
        this.dataRozpoczecia = dataRozpoczecia;
    }

    public Date getDataZakonczenia() {
        return dataZakonczenia;
    }

    public void setDataZakonczenia(Date dataZakonczenia) {
        this.dataZakonczenia = dataZakonczenia;
    }

    public int getIdUzytkownikaSprzedajacego() {
        return idUzytkownikaSprzedajacego;
    }

    public void setIdUzytkownikaSprzedajacego(int idUzytkownikaSprzedajacego) {
        this.idUzytkownikaSprzedajacego = idUzytkownikaSprzedajacego;
    }

    public Integer getIdUzytkownikaWygrywajacego() {
        return idUzytkownikaWygrywajacego;
    }

    public void setIdUzytkownikaWygrywajacego(Integer idUzytkownikaWygrywajacego) {
        this.idUzytkownikaWygrywajacego = idUzytkownikaWygrywajacego;
    }
    
     public String getStatusAukcji() {
        return statusAukcji;
    }

    public void setStatusAukcji(String statusAukcji) {
        this.statusAukcji = statusAukcji;
    }
    

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (idAukcji != null ? idAukcji.hashCode() : 0);
        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 Aukcja)) {
            return false;
        }
        Aukcja other = (Aukcja) object;
        if ((this.idAukcji == null && other.idAukcji != null) || (this.idAukcji != null && !this.idAukcji.equals(other.idAukcji))) {
            return false;
        }
        return true;
    }

    @Override
    public String toString() {
        return "com.aukcje.aukcjewebap.encje.Aukcja[ idAukcji=" + idAukcji + " ]";
    }
    
}


Kategoria


package encje;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Collection;
import javax.persistence.Basic;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;
import javax.xml.bind.annotation.XmlRootElement;

/**
 *
 * @author oracle
 */
@Entity
@Table(name = "Kategoria")
@XmlRootElement
@NamedQueries({
    @NamedQuery(name = "Kategoria.findAll", query = "SELECT k FROM Kategoria k ORDER BY k.idKategoria"),
    @NamedQuery(name = "Kategoria.findByIdKategoria", query = "SELECT k FROM Kategoria k WHERE k.idKategoria = :idKategoria"),
    @NamedQuery(name = "Kategoria.findByNazwaKategorii", query = "SELECT k FROM Kategoria k WHERE k.nazwaKategorii = :nazwaKategorii")})
public class Kategoria implements Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @Basic(optional = false)
    @NotNull
    @Column(name = "id_kategoria")
    private Integer idKategoria;
    @Basic(optional = false)
    @NotNull
    @Size(min = 1, max = 45)
    @Column(name = "nazwa_kategorii")
    private String nazwaKategorii;
    
    
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "kategoria")
    private Collection<Aukcja> aukcje = new ArrayList<>(); 

    public Kategoria() {
    }

    public Kategoria(Integer idKategoria) {
        this.idKategoria = idKategoria;
    }

    public Kategoria(Integer idKategoria, String nazwaKategorii) {
        this.idKategoria = idKategoria;
        this.nazwaKategorii = nazwaKategorii;
    }

    public Integer getIdKategoria() {
        return idKategoria;
    }

    public void setIdKategoria(Integer idKategoria) {
        this.idKategoria = idKategoria;
    }

    public String getNazwaKategorii() {
        return nazwaKategorii;
    }

    public void setNazwaKategorii(String nazwaKategorii) {
        this.nazwaKategorii = nazwaKategorii;
    }

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (idKategoria != null ? idKategoria.hashCode() : 0);
        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 Kategoria)) {
            return false;
        }
        Kategoria other = (Kategoria) object;
        if ((this.idKategoria == null && other.idKategoria != null) || (this.idKategoria != null && !this.idKategoria.equals(other.idKategoria))) {
            return false;
        }
        return true;
    }

    @Override
    public String toString() {
        return "com.aukcje.aukcjewebap.encje.Kategoria[ idKategoria=" + idKategoria + " ]";
    }
    
}

tabela MySql

CREATE TABLE `Aukcja` (
  `id_aukcji` int(11) NOT NULL AUTO_INCREMENT,
  `id_kategoria` int(11) NOT NULL,
  `tytul` varchar(45) NOT NULL,
  `opis` varchar(200) DEFAULT NULL,
  `aktualna_cena` decimal(8,2) NOT NULL,
  `data_rozpoczecia` datetime NOT NULL,
  `data_zakonczenia` datetime DEFAULT NULL,
  `id_uzytkownika_sprzedajacego` int(11) NOT NULL,
  `id_uzytkownika_wygrywajacego` int(11) DEFAULT NULL,
  `status_aukcji` varchar(15) DEFAULT NULL,
  `wersja` int(11) DEFAULT NULL,
  PRIMARY KEY (`id_aukcji`),
  UNIQUE KEY `idnew_table_UNIQUE` (`id_aukcji`)
) ENGINE=InnoDB AUTO_INCREMENT=14 DEFAULT CHARSET=latin1;


CREATE TABLE `Kategoria` (
  `id_kategoria` int(11) NOT NULL,
  `nazwa_kategorii` varchar(45) NOT NULL,
  PRIMARY KEY (`id_kategoria`),
  UNIQUE KEY `id_kategoria_UNIQUE` (`id_kategoria`),
  UNIQUE KEY `nazwa_kategorii_UNIQUE` (`nazwa_kategorii`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
/*!40101 SET character_set_client = @saved_cs_client */;


błąd przy próbie dodania rekordu do encji Aukcja

javax.faces.el.EvaluationException: javax.ejb.EJBException: Transaction aborted
	at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:101)
	at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:102)
	at javax.faces.component.UICommand.broadcast(UICommand.java:315)
	at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:790)
	at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1282)
	at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81)
	at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
	at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
	at javax.faces.webapp.FacesServlet.service(FacesServlet.java:646)
	at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:318)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:160)
	at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:734)
	at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:673)
	at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:99)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:174)
	at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:415)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:282)
	at com.sun.enterprise.v3.services.impl.ContainerMapper$HttpHandlerCallable.call(ContainerMapper.java:459)
	at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:167)
	at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:201)
	at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:175)
	at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:235)
	at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)
	at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:284)
	at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:201)
	at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:133)
	at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:112)
	at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)
	at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:561)
	at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:112)
	at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:117)
	at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:56)
	at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:137)
	at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:565)
	at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:545)
	at java.lang.Thread.run(Thread.java:745)
Caused by: javax.ejb.EJBException: Transaction aborted
	at com.sun.ejb.containers.EJBContainerTransactionManager.completeNewTx(EJBContainerTransactionManager.java:725)
	at com.sun.ejb.containers.EJBContainerTransactionManager.postInvokeTx(EJBContainerTransactionManager.java:503)
	at com.sun.ejb.containers.BaseContainer.postInvokeTx(BaseContainer.java:4566)
	at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:2074)
	at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:2044)
	at com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:220)
	at com.sun.ejb.containers.EJBLocalObjectInvocationHandlerDelegate.invoke(EJBLocalObjectInvocationHandlerDelegate.java:88)
	at com.sun.proxy.$Proxy323.zapiszPoRejestracjiAukcje(Unknown Source)
	at AukcjaController.AukcjaController.zapiszPoRejestracjiAukcje(AukcjaController.java:120)
	at AukcjaController.DodajAukcje.zapiszAukcja(DodajAukcje.java:44)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:497)
	at javax.el.ELUtil.invokeMethod(ELUtil.java:332)
	at javax.el.BeanELResolver.invoke(BeanELResolver.java:537)
	at javax.el.CompositeELResolver.invoke(CompositeELResolver.java:256)
	at com.sun.el.parser.AstValue.invoke(AstValue.java:283)
	at com.sun.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:304)
	at org.jboss.weld.util.el.ForwardingMethodExpression.invoke(ForwardingMethodExpression.java:40)
	at org.jboss.weld.el.WeldMethodExpression.invoke(WeldMethodExpression.java:50)
	at com.sun.faces.facelets.el.TagMethodExpression.invoke(TagMethodExpression.java:105)
	at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:87)
	... 36 more
Caused by: javax.transaction.RollbackException: Transaction marked for rollback.
	at com.sun.enterprise.transaction.JavaEETransactionImpl.commit(JavaEETransactionImpl.java:490)
	at com.sun.enterprise.transaction.JavaEETransactionManagerSimplified.commit(JavaEETransactionManagerSimplified.java:854)
	at com.sun.ejb.containers.EJBContainerTransactionManager.completeNewTx(EJBContainerTransactionManager.java:719)
	... 58 more
Caused by: javax.persistence.PersistenceException: Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.5.2.v20140319-9ad6abd): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'kategoria' in 'field list'
Error Code: 1054
Call: INSERT INTO Aukcja (aktualna_cena, data_rozpoczecia, data_zakonczenia, id_kategoria, id_uzytkownika_sprzedajacego, id_uzytkownika_wygrywajacego, opis, status_aukcji, tytul, WERSJA, kategoria) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
	bind => [11 parameters bound]
Query: InsertObjectQuery(com.aukcje.aukcjewebap.encje.Aukcja[ idAukcji=null ])
	at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl$1.handleException(EntityManagerSetupImpl.java:696)
	at org.eclipse.persistence.transaction.AbstractSynchronizationListener.handleException(AbstractSynchronizationListener.java:275)
	at org.eclipse.persistence.transaction.AbstractSynchronizationListener.beforeCompletion(AbstractSynchronizationListener.java:170)
	at org.eclipse.persistence.transaction.JTASynchronizationListener.beforeCompletion(JTASynchronizationListener.java:68)
	at com.sun.enterprise.transaction.JavaEETransactionImpl.commit(JavaEETransactionImpl.java:452)
	... 60 more
Caused by: Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.5.2.v20140319-9ad6abd): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'kategoria' in 'field list'
Error Code: 1054
Call: INSERT INTO Aukcja (aktualna_cena, data_rozpoczecia, data_zakonczenia, id_kategoria, id_uzytkownika_sprzedajacego, id_uzytkownika_wygrywajacego, opis, status_aukcji, tytul, WERSJA, kategoria) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
	bind => [11 parameters bound]
Query: InsertObjectQuery(com.aukcje.aukcjewebap.encje.Aukcja[ idAukcji=null ])
	at org.eclipse.persistence.exceptions.DatabaseException.sqlException(DatabaseException.java:331)
	at org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.executeDirectNoSelect(DatabaseAccessor.java:900)
	at org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.executeNoSelect(DatabaseAccessor.java:962)
	at org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.basicExecuteCall(DatabaseAccessor.java:631)
	at org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.executeCall(DatabaseAccessor.java:558)
	at org.eclipse.persistence.internal.sessions.AbstractSession.basicExecuteCall(AbstractSession.java:2002)
	at org.eclipse.persistence.sessions.server.ClientSession.executeCall(ClientSession.java:298)
	at org.eclipse.persistence.internal.queries.DatasourceCallQueryMechanism.executeCall(DatasourceCallQueryMechanism.java:242)
	at org.eclipse.persistence.internal.queries.DatasourceCallQueryMechanism.executeCall(DatasourceCallQueryMechanism.java:228)
	at org.eclipse.persistence.internal.queries.DatasourceCallQueryMechanism.insertObject(DatasourceCallQueryMechanism.java:377)
	at org.eclipse.persistence.internal.queries.StatementQueryMechanism.insertObject(StatementQueryMechanism.java:165)
	at org.eclipse.persistence.internal.queries.StatementQueryMechanism.insertObject(StatementQueryMechanism.java:180)
	at org.eclipse.persistence.internal.queries.DatabaseQueryMechanism.insertObjectForWrite(DatabaseQueryMechanism.java:489)
	at org.eclipse.persistence.queries.InsertObjectQuery.executeCommit(InsertObjectQuery.java:80)
	at org.eclipse.persistence.queries.InsertObjectQuery.executeCommitWithChangeSet(InsertObjectQuery.java:90)
	at org.eclipse.persistence.internal.queries.DatabaseQueryMechanism.executeWriteWithChangeSet(DatabaseQueryMechanism.java:301)
	at org.eclipse.persistence.queries.WriteObjectQuery.executeDatabaseQuery(WriteObjectQuery.java:58)
	at org.eclipse.persistence.queries.DatabaseQuery.execute(DatabaseQuery.java:899)
	at org.eclipse.persistence.queries.DatabaseQuery.executeInUnitOfWork(DatabaseQuery.java:798)
	at org.eclipse.persistence.queries.ObjectLevelModifyQuery.executeInUnitOfWorkObjectLevelModifyQuery(ObjectLevelModifyQuery.java:108)
	at org.eclipse.persistence.queries.ObjectLevelModifyQuery.executeInUnitOfWork(ObjectLevelModifyQuery.java:85)
	at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.internalExecuteQuery(UnitOfWorkImpl.java:2896)
	at org.eclipse.persistence.internal.sessions.AbstractSession.executeQuery(AbstractSession.java:1804)
	at org.eclipse.persistence.internal.sessions.AbstractSession.executeQuery(AbstractSession.java:1786)
	at org.eclipse.persistence.internal.sessions.AbstractSession.executeQuery(AbstractSession.java:1737)
	at org.eclipse.persistence.internal.sessions.CommitManager.commitNewObjectsForClassWithChangeSet(CommitManager.java:226)
	at org.eclipse.persistence.internal.sessions.CommitManager.commitAllObjectsWithChangeSet(CommitManager.java:125)
	at org.eclipse.persistence.internal.sessions.AbstractSession.writeAllObjectsWithChangeSet(AbstractSession.java:4207)
	at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.commitToDatabase(UnitOfWorkImpl.java:1441)
	at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.commitToDatabaseWithChangeSet(UnitOfWorkImpl.java:1531)
	at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.issueSQLbeforeCompletion(UnitOfWorkImpl.java:3168)
	at org.eclipse.persistence.internal.sessions.RepeatableWriteUnitOfWork.issueSQLbeforeCompletion(RepeatableWriteUnitOfWork.java:352)
	at org.eclipse.persistence.transaction.AbstractSynchronizationListener.beforeCompletion(AbstractSynchronizationListener.java:158)
	... 62 more
Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'kategoria' in 'field list'
	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
	at java.lang.reflect.Constructor.newInstance(Constructor.java:422)
	at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
	at com.mysql.jdbc.Util.getInstance(Util.java:386)
	at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1053)
	at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4120)
	at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:4052)
	at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2503)
	at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2664)
	at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2794)
	at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2155)
	at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2458)
	at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2375)
	at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2359)
	at org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.executeDirectNoSelect(DatabaseAccessor.java:890)
	... 93 more


 
0
Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'kategoria' in 'field list'

Masz na tej bazie ustawione create-drop? Bo moze się po prostu tabele nie zmodyfikowały po tej zmianie? Poza tym używaj Set a nie Collection albo List. No i nie ogarniam czemu dodajesz ręcznie takie cuda jak id albo @JoinColumn albo @Table skoro są identyczne jak te generowane automatycznie. Lubisz mieć tonę śmieci w kodzie? o_O

0

dzięki zapomniałem o pliku persistence.xml i tym ustawieniu w nim ruszył druga aplikacja dopiero w jee

tak to prawda ale robię to na zaliczenie i w dodatku etapami

w książkach piszą to często te join itp. i w necie przykłady też

choć to domyślnie sam dobiera sobie nie piszę zawodowo więc takie zapisy się pojawiły ale rozumiem uwagę

1

Warto wiedzieć że pewne parametry da sie ręcznie konfigurować (jony, nazwy tabel etc), ale wpychanie tego na siłę do projektu gdzie jest to zbędne jest, moim zdaniem, błędem i nie powinno mieć miejsca ;) Bo taki kod jest niepotrzebne rozwlekły i trudniej się go czyta.

0

dzięki wartowiedzieć jak zawodowo to się pisze

1 użytkowników online, w tym zalogowanych: 0, gości: 1