hibernate问题,太奇怪了,就是搞不明白
我在tomcat中配置的数据源<Context path="/teach" docBase="D:\eclipse\work\teach\WebRoot" reloadable="false">
<Resource
name="jdbc/teach"
type="javax.sql.DataSource"
factory="org.apache.commons.dbcp.BasicDataSourceFactory"
username="sa"
password=""
driverClassName="com.microsoft.jdbc.sqlserver.SQLServersDriver"
maxIdle="10"
maxWait="15000"
maxActive="50"
url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=teaching"/>
</Context>
在hibernate中的配置文件
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
<session-factory>
<property name="connection.datasource">java:comp/env/jdbc/teach</property>
<property name="connection.username">sa</property>
<property name="dialect">
org.hibernate.dialect.SQLServerDialect
</property>
<mapping resource="jjq/vo/Institute.hbm.xml" />
</session-factory>
</hibernate-configuration>
可是我在程序中运行出错:
Exception in thread "main" java.lang.ExceptionInInitializerError
at jjq.test.test1.main(test1.java:16)
Caused by: java.lang.RuntimeException: Configuration problem: Could not find datasource
at jjq.util.HibernateUtil.<clinit>(HibernateUtil.java:18)
... 1 more
Caused by: org.hibernate.HibernateException: Could not find datasource
at org.hibernate.connection.DatasourceConnectionProvider.configure(DatasourceConnectionProvider.java:56)
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:366)
at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:60)
at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:1881)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1174)
at jjq.util.HibernateUtil.<clinit>(HibernateUtil.java:16)
... 1 more
Caused by: javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file: java.naming.factory.initial
at javax.naming.spi.NamingManager.getInitialContext(NamingManager.java:645)
at javax.naming.InitialContext.getDefaultInitCtx(InitialContext.java:247)
at javax.naming.InitialContext.getURLOrDefaultInitCtx(InitialContext.java:284)
at javax.naming.InitialContext.lookup(InitialContext.java:351)
at org.hibernate.connection.DatasourceConnectionProvider.configure(DatasourceConnectionProvider.java:52)
... 8 more
我的程序是package jjq.test;
import java.util.Iterator;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import jjq.util.*;
public class test1 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Session s=HibernateUtil.currentSession();
Query q=s.createQuery("FROM Institute");
//Iterator l=q.iterate();
List l=q.list();
Iterator iter=l.iterator();
while(iter.hasNext())
{
System.out.println(iter.next());
}
}
}
我就搞不懂是怎么回事了!~
还有个疑问:因为这种配置是按教程上写的,可是我就不明白了,现在和tomcat有什么关系呢?(虽然我测试时tomcat是开着的)