如何解决WFLYEJB0406:找不到绑定控制器为'ejb_accountcrud.IAccountCrud'类型的接口的EJBLoginBean/ accountServ
我不知道是什么问题。我已经尝试过org.hibernate.dialect.MySQL5Dialect,可以启用通过互联网发现的hybernate和其他功能,但是似乎没有什么能指出问题所在。
我已经创建了其他一些项目,但这是我第一次遇到这个东西。
表A
import java.io.Serializable;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToOne;
import javax.persistence.Table;
import javax.persistence.UniqueConstraint;
@Entity
@Table (name ="abbigliamento",uniqueConstraints=@UniqueConstraint(columnNames= {"prezzo"}))
public class Abbigliamento implements Serializable{
/**
*
*/
private static final long serialVersionUID = 6587541972395128627L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column (name="id")
private int id;
@Column (name="nome")
private String nome;
@Column (name="taglia")
private String taglia;
@Column (name="colore")
private String colore;
@Column (name="descrizione")
private String descrizione;
@Column (name="quantita")
private int quantita;
@Column (name="disponibilita")
private boolean disponibilita;
@Column(name="prezzo",unique=true,nullable=false)
private double prezzo;
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="Id_reparto")
private Reparti reparti;
@OneToOne(cascade=CascadeType.ALL)
@JoinColumn(name="bolla_acquisto")
private BollaacquistoAbbigliamento bollaAcquisto;
//getter/setter
表B
@Entity
@Table (name ="bollaacquistoabbigliamento",uniqueConstraints=@UniqueConstraint(columnNames= {"codice_acquisto"}) )
public class BollaacquistoAbbigliamento implements Serializable {
/**
*
*/
private static final long serialVersionUID = -3084091051025520907L;
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
private int id;
@Column(name="nome_fornitore/venditore")
private String nomeFV;
@Column(name="codice_acquisto",nullable=false)
private long codiceAcquisto;
@Column(name="data_acquisto")
private String dataAcquisto;
@Column(name="stock_acquistato")
private String stock;
@Column(name="prezzo_totale")
private double prTotale;
@Column(name="prezzo_unitario")
private double prUnitario;
@OneToOne
@MapsId
private Abbigliamento abbigliamento;
控制台错误
[org.hibernate.tool.schema.internal.ExceptionHandlerLoggedImpl](ServerService线程池-76)GenerationTarget遇到异常接受命令:执行DDL错误“创建表bollaacquistoabbigliamento(codice_acquisto bigint不为null,data_acquisto varchar(255),nome_fornitore / venditore varchar(255),prezzo_totale double,prezzo_unitario double,stock_acquistato varchar(255),abbigliamento_id整数不为null,主键(abbigliamento_id))”通过JDBC语句:org.hibernate.tool.schema.spi.CommandAcceptanceException:执行DDL时出错“创建表bollaacquistoabbigliamento(codice_acquisto bigint不为null,data_acquisto varchar(255),nome_fornitore / venditore varchar(255),prezzo_totale double,prezzo_unitario double,stock_acquistato varchar(255),abbigliamento_id整数,abb)声明 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.internal.exec.GenerationTargetToDatabase.accept(GenerationTargetToDatabase.java:67) 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.internal.AbstractSchemaMigrator.applySqlString(AbstractSchemaMigrator.java:559) 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.internal.AbstractSchemaMigrator.applySqlStrings(AbstractSchemaMigrator.java:504) 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.internal.AbstractSchemaMigrator.createTable(AbstractSchemaMigrator.java:277) 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.internal.GroupedSchemaMigratorImpl.performTablesMigration(GroupedSchemaMigratorImpl.java:71) 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.internal.AbstractSchemaMigrator.performMigration(AbstractSchemaMigrator.java:207) 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.internal.AbstractSchemaMigrator.doMigration(AbstractSchemaMigrator.java:114) 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.spi.SchemaManagementToolCoordinator.performDatabaseAction(SchemaManagementToolCoordinator.java:183) 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.spi.SchemaManagementToolCoordinator.process(SchemaManagementToolCoordinator.java:72) 在org.hibernate@5.3.10.Final//org.hibernate.internal.SessionFactoryImpl。(SessionFactoryImpl.java:310) 在org.hibernate@5.3.10.Final//org.hibernate.boot.internal.SessionFactoryBuilderImpl.build(SessionFactoryBuilderImpl.java:467) 在org.hibernate@5.3.10.Final//org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:939) 在org.hibernate.jipijapa-hibernate5-3@17.0.1.Final//org.jboss.as.jpa.hibernate5.TwoPhaseBootstrapImpl.build(TwoPhaseBootstrapImpl.java:44) 在org.jboss.as.jpa@17.0.1.Final//org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1$1.run(PersistenceUnitServiceImpl.java:170) 在org.jboss.as.jpa@17.0.1.Final//org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1$1.run(PersistenceUnitServiceImpl.java:128) 在org.wildfly.security.elytron-private@1.9.1.Final//org.wildfly.security.manager.WildFlySecurityManager.doChecked(WildFlySecurityManager.java:649) 在org.jboss.as.jpa@17.0.1.Final//org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1.run(PersistenceUnitServiceImpl.java:212) 在org.jboss.threads@2.3.3.Final//org.jboss.threads.ContextClassLoaderSavingRunnable.run(ContextClassLoaderSavingRunnable.java:35) 在org.jboss.threads@2.3.3.Final//org.jboss.threads.EnhancedQueueExecutor.safeRun(EnhancedQueueExecutor.java:1982) 在org.jboss.threads@2.3.3.Final//org.jboss.threads.EnhancedQueueExecutor$ThreadBody.doRunTask(EnhancedQueueExecutor.java:1486) 在org.jboss.threads@2.3.3.Final//org.jboss.threads.EnhancedQueueExecutor$ThreadBody.run(EnhancedQueueExecutor.java:1377) 在java.base / java.lang.Thread.run(Thread.java:830) 在org.jboss.threads@2.3.3.Final//org.jboss.threads.JBossThread.run(JBossThread.java:485) 原因:org.h2.jdbc.JdbcSQLException:未知数据类型:“ /”; SQL语句: 创建表bollaacquistoabbigliamento(codice_acquisto bigint不为null,data_acquisto varchar(255),nome_fornitore / venditore varchar(255),prezzo_totale double,prezzo_unitario double,stock_acquistato varchar(255),abbigliamento_id整数(abb)(193) ] 在com.h2database.h2@1.4.193//org.h2.message.DbException.getJdbcSQLException(DbException.java:345) 在com.h2database.h2@1.4.193//org.h2.message.DbException.get(DbException.java:179) 在com.h2database.h2@1.4.193//org.h2.message.DbException.get(DbException.java:155) 在com.h2database.h2@1.4.193//org.h2.command.Parser.parseColumnWithType(Parser.java:4080) 在com.h2database.h2@1.4.193//org.h2.command.Parser.parseColumnForTable(Parser.java:3938) 在com.h2database.h2@1.4.193//org.h2.command.Parser.parseCreateTable(Parser.java:5977) 在com.h2database.h2@1.4.193//org.h2.command.Parser.parseCreate(Parser.java:4238) 在com.h2database.h2@1.4.193//org.h2.command.Parser.parsePrepared(Parser.java:362) 在com.h2database.h2@1.4.193//org.h2.command.Parser.parse(Parser.java:317) 在com.h2database.h2@1.4.193//org.h2.command.Parser.parse(Parser.java:289) 在com.h2database.h2@1.4.193//org.h2.command.Parser.prepareCommand(Parser.java:254) 在com.h2database.h2@1.4.193//org.h2.engine.Session.prepareLocal(Session.java:561) 在com.h2database.h2@1.4.193//org.h2.engine.Session.prepareCommand(Session.java:502) 在com.h2database.h2@1.4.193//org.h2.jdbc.JdbcConnection.prepareCommand(JdbcConnection.java:1203) 在com.h2database.h2@1.4.193//org.h2.jdbc.JdbcStatement.executeInternal(JdbcStatement.java:170) 在com.h2database.h2@1.4.193//org.h2.jdbc.JdbcStatement.execute(JdbcStatement.java:158) 在org.jboss.ironjacamar.jdbcadapters@1.4.16.Final//org.jboss.jca.adapters.jdbc.WrappedStatement.execute(WrappedStatement.java:198) 在org.hibernate@5.3.10.Final//org.hibernate.tool.schema.internal.exec.GenerationTargetToDatabase.accept(GenerationTargetToDatabase.java:54) ... 22更多
其他2个表也发生相同的错误。
非常感谢,祝您愉快!
解决方法
有时有助于阅读错误消息:
Caused by: org.h2.jdbc.JdbcSQLException: Unknown data type: "/"; SQL statement: create table bollaacquistoabbigliamento (codice_acquisto bigint not null,data_acquisto varchar(255),nome_fornitore/venditore varchar(255),prezzo_totale double,prezzo_unitario double,stock_acquistato varchar(255),abbigliamento_id integer not null,primary key (abbigliamento_id))
所以也许您不应该为列nome_fornitore/venditore
命名,因为正斜杠会导致错误。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。