使用SessionFactory时Hibernate中的奇怪NumberFormatException

时间:2013-05-09 17:31:14

标签: java mysql database eclipse hibernate

[今天早些时候在Hibernate Schema Export in Eclipse看到我的相关但又截然不同的问题可能会有用。{/ p>

我有以下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文件中的错误,类路径排序问题,文件不在正确的目录中等)为什么会发生这种行为?”。

对此问题的回答也可能有助于解决本页最顶层链接中导出架构的问题。

谢谢,Conor。

2 个答案:

答案 0 :(得分:1)

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

修好后,我们开始在这行代码上看到NullPointerException

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

看一下这行代码,唯一可能抛出NPE的是getClassLoader调用,但是怎么可能是null呢?事实证明,如果返回的类加载器是引导类加载器,getClassLoader可以返回null。我让Conor检查他是否已将hibernate放入引导类路径,结果证明他做了。从引导类中删除它修复了问题。

这里有两个教训:

  1. 仔细管理您的课程路径。知道它上面有什么,并尽可能保持修剪。较少的第三方库更好。
  2. 不要把东西放在引导类路径上。如果您决定忽略此规则,请了解潜在影响是什么,这样您就不会遇到这样的问题。

答案 1 :(得分:0)

数据库id列数据类型是整数,但实体类的id数据类型很长,不确定这是否是问题。 但值得尝试将实体id的数据类型更改为int。