[在今天的Hibernate Schema Export in Eclipse处看到我的相关但又截然不同的问题可能很有用。]

我有以下Java课

package com.examscam.model;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.tool.hbm2ddl.SchemaExport;

@Entity
public class User {
    private Long id;
    private String password;

    @Id
    @GeneratedValue
    public Long getId() {
        return id;
    }

    public String getPassword() {
        return password;
    }

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

    public void setPassword(String password) {
        this.password = password;
    }

    public static void main(String[] args) {
        AnnotationConfiguration config = new AnnotationConfiguration();
        config.addAnnotatedClass(User.class);
        config.configure();
//      new SchemaExport(config).create(true, true);

        SessionFactory factory = config.buildSessionFactory();
        Session session = factory.getCurrentSession();
        session.beginTransaction();

        User u = new User();
        u.setPassword("abc123");

        session.saveOrUpdate(u);
        session.getTransaction().commit();

        System.out.println("Done.");
    }
}


我有一个(MySQL)数据库,并使用代码创建了User表

create table User (id integer not null auto_increment, password varchar(255), primary key (id))


但是,当我尝试运行此代码时,将获得以下堆栈跟踪

Exception in thread "main" java.lang.NumberFormatException: For input string: ""
    at java.lang.NumberFormatException.forInputString(NumberFormatException.java:48)
    at java.lang.Integer.parseInt(Integer.java:470)
    at java.lang.Integer.valueOf(Integer.java:554)
    at org.hibernate.util.PropertiesHelper.getInteger(PropertiesHelper.java:37)
    at org.hibernate.connection.DriverManagerConnectionProvider.configure(DriverManagerConnectionProvider.java:47)
    at org.hibernate.connection.ConnectionProviderFactory.newConnectionProvider(ConnectionProviderFactory.java:124)
    at org.hibernate.connection.ConnectionProviderFactory.newConnectionProvider(ConnectionProviderFactory.java:56)
    at org.hibernate.cfg.SettingsFactory.createConnectionProvider(SettingsFactory.java:414)
    at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:62)
    at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2009)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1292)
    at org.hibernate.cfg.AnnotationConfiguration.buildSessionFactory(AnnotationConfiguration.java:859)
    at com.examscam.model.User.main(User.java:40)


User类的第40行是

    SessionFactory factory = config.buildSessionFactory();


有谁知道为什么会这样吗?我没有在该行的任何地方输入空字符串,而是完全从书中复制了代码。我毫不怀疑这本书是正确的。我的问题更像是“任何人都能想到为什么会发生此现象的任何原因(xml文件中的错误,类路径排序问题,文件不在正确的目录中等等)”。

这个问题的答案也可能有助于解决此页面顶部链接中的有关导出模式的问题。

谢谢,康纳

最佳答案

所以我相信我已经解决了这个问题,最终导致了两个问题。首先,在类路径中还有另一个较旧的休眠模式副本。这个较旧的版本需要不再需要的配置元素,导致NumberFormatException,因为它试图将空字符串解析为int以获取缺少的事务隔离配置元素。

解决此问题后,我们开始在此代码行上看到NullPointerException

Environment.class.getClassLoader().getResourceAsStream(stripped);


看着那行代码,唯一可能抛出NPE的东西是getClassLoader调用,但是那怎么可能为空呢?事实证明,如果要返回的类加载器是引导类加载器,则getClassLoader可以返回null。我要求康纳尔(Conor)检查他是否已将休眠状态放入引导类路径,事实证明他确实这样做了。从引导类中删除它可以解决此问题。

所以这里有两课:


仔细管理您的课堂路径。知道上面有什么,并使其尽可能修剪。第三方解放越少越好。
永远不要在启动类路径上放东西。如果您决定忽略此规则,请了解潜在的含义,以免您陷入这样的问题。

09-07 05:28