Hibernate基础之一:Hibernate4.1.6第一个程序



    Hibernate4和3在细节上有挺多不一样的地方,今儿就吃了苦头,花了一两个小时解决两个环境问题引起的Exception。比如Could not parse mapping document from resource这个异常是我照着英文文档他写的类才改过来的。


    先贴出源码吧,有几个异常网上没有正确的解决方案,用 Hibernate4.1.x出同样问题的先粘走试试,

    第二部分说下异常的解决。


一:源码:

1.Oracle11建表

一:建表
DROP TABLE student;
CREATE TABLE student  
(  
    studentid NUMBER(9),  
    name VARCHAR2(50) NOT NULL,  
    age NUMBER(9) NOT NULL,  
    CONSTRAINT student_studentid_pk PRIMARY KEY(studentid)   
); 


2.建工程,倒库

2.1导入\hibernate-release-4.1.6.Final\lib下所有的库

2.2导入\slf4j-1.6.1\slf4j-nop-1.6.1.jar(单独下载的,不是hibernate里的api)

2.3导入Oracle\Administrator\product\11.2.0\dbhome_1\jdbc\lib\ojdbc6.jar


3.java类和测试类

package com.rt.hibernate.demo;

public class Student {
	
	private int studentid;
	private String name;
	private int age;
	
	//setter&getter
	public int getStudentid() {
		return studentid;
	}
	public void setStudentid(int studentid) {
		this.studentid = studentid;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
		
}


package com.rt.hibernate.demo;
//import javax.transaction.Transaction;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;



public class StudentTest {
	
	public static void main(String[] args)
	{
		Student sd = new Student();
		sd.setStudentid(1100);
		sd.setName("zhangsan");
		sd.setAge(23);
		
		//准备工作
		SessionFactory sessionFactory;
		sessionFactory = new Configuration().configure().buildSessionFactory(); 
		Session session = sessionFactory.openSession();  
        Transaction transaction = session.beginTransaction(); 
        //保存对象
        session.save(sd);
        //收尾工作
        transaction.commit(); 
        session.close(); 
        sessionFactory.close(); 
	}
}


4.hibernate.cfg.xml

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

    <session-factory>

        <!-- Database connection settings -->
        <property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
        <property name="connection.url">jdbc:oracle:thin:@localhost:1521:ORCL</property>
        <property name="connection.username">scott</property>
        <property name="connection.password">890307</property>

        <!-- JDBC connection pool (use the built-in) -->
        <!-- <property name="connection.pool_size">1</property>  -->

        <!-- SQL dialect -->
        <property name="dialect">org.hibernate.dialect.Oracle10gDialect</property>

        <!-- Enable Hibernate's automatic session context management -->
        <!-- <property name="current_session_context_class">thread</property>  -->

        <!-- Disable the second-level cache  -->
        <property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>

        <!-- Echo all executed SQL to stdout -->
        <property name="show_sql">true</property>

        <!-- Drop and re-create the database schema on startup -->
        <!-- <property name="hbm2ddl.auto">update</property> -->

        <mapping resource="com/rt/hibernate/demo/Student.hbm.xml"/><!-- 对应java类的配置文件 -->

    </session-factory>

</hibernate-configuration>


5.Student.hbm.xml

<?xml version="1.0"?>  
<!DOCTYPE hibernate-mapping PUBLIC  
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">  
<hibernate-mapping package="com.rt.hibernate.demo">  
    <class name="Student">  
        <id name="studentid">  
        </id>  
        <property name="name"/>  
        <property name="age"/>  
    </class>  
</hibernate-mapping> 








二:今晚处理的Hibernate异常

1.Connection cannot be null when 'hibernate.dialect' not set

说是dialect设置没有,确认配过以下信息(对应Oracle类型查一下)的,

        <!-- SQL dialect -->
        <property name="dialect">org.hibernate.dialect.Oracle10gDialect</property>

换用我测试类里session的设置和save()方法试试。

//准备工作
SessionFactory sessionFactory;
sessionFactory = new Configuration().configure().buildSessionFactory(); 
Session session = sessionFactory.openSession();  
Transaction transaction = session.beginTransaction(); 
//保存对象
session.save(sd);
//收尾工作
transaction.commit(); 
session.close(); 
sessionFactory.close(); 
我用别的方法也能消掉这个异常,可是会出下边第二个异常


2.Could not parse mapping document from resource *.hbm.xml 

    这个最头疼。
    网上查到的资料都是说xml文件格式的,我换了n中格式可是问题依旧
    知道Hibernate4和3在sessionFactory不同,就换了n多种方法都不行
    然后看具体错误信息,提示是:processHbmXml,我就又仔仔细细检查了n遍

    最后查到一个英文的示例,照着改了一下成了现在用的session.save()的设置和保存方法(解决异常1的方法),才把异常消掉……




3.无法将 NULL 插入

   这个怪自己粗细大意,考来的建表脚本有NOT NULL,没消干净







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值