hibernate问题,太奇怪了,就是搞不明白

jjqibmbld1 2008-04-09 02:15:44
我在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是开着的)
...全文
243 19 打赏 收藏 转发到动态 举报
写回复
用AI写文章
19 条回复
切换为时间正序
请发表友善的回复…
发表回复
cchaha 2008-05-02
  • 打赏
  • 举报
回复
放到WEB目录下面通过URL访问测试,不要用MAIN方法,这样是取不到WEB的上下文的,如果要用MAIN方法测试,用单元测试来构建代码,我没试过,不知道行不行,只是给个建议
lifeiping 2008-05-01
  • 打赏
  • 举报
回复
不能找到数据源,看一下数据源配置,是否没有导入驱动文件啊
beizehao 2008-04-29
  • 打赏
  • 举报
回复
我帮你一起顶
gongyali2005 2008-04-29
  • 打赏
  • 举报
回复
数据源,只能在JSP里测试.
不可以在MANI方法.

OVER.
aChinese 2008-04-29
  • 打赏
  • 举报
回复
你那个是什么版本的Tomcat? 每种写法不太一样, 给你一种吧
<Context path="/teach" docBase="D:\eclipse\work\teach\WebRoot" reloadable="false">
<ResourceParams name="jdbc/teach">
<parameter>
<name>factory</name>
<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
</parameter>
<parameter>
<name>driverClassName</name>
<value>com.microsoft.jdbc.sqlserver.SQLServersDriver</value>
</parameter>
<parameter>
<name>url</name>
<value>jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=teaching</value>
</parameter>
<parameter>
<name>username</name>
<value>sa</value>
</parameter>
<parameter>
<name>password</name>
<value></value>
</parameter>
<parameter>
<name>maxActive</name>
<value>20</value>
</parameter>
<parameter>
<name>maxIdle</name>
<value>5</value>
</parameter>
<parameter>
<name>maxWait</name>
<value>-1</value>
</parameter>
</ResourceParams>
</Context>
jjqibmbld1 2008-04-12
  • 打赏
  • 举报
回复
我自己给定起来
jjqibmbld1 2008-04-11
  • 打赏
  • 举报
回复
wuy13862574600 :
是啊,问题是我对数据库的操作要封装到bean里,而不是直接写在jsp页面中啊!
jjqibmbld1 2008-04-10
  • 打赏
  • 举报
回复
有过一天还是没人能解答!~
wuy13862574600 2008-04-10
  • 打赏
  • 举报
回复
lookup()
读取上下文是在web项目才能取到上下文,所以你在main方法中是拿不到数据源,在页面就可以
ok,不是很难的问题。。
flyices 2008-04-10
  • 打赏
  • 举报
回复
你不要在Tomcat里边配置数据源!要在Hibernate里配置!你这样做Hibernate可以去跳楼了!
sky_ccy 2008-04-10
  • 打赏
  • 举报
回复
兄弟,你 是用 eclipse开发 的吗 ,在 加入hibernate的 时候,就 要 选择数据源呀 ,,你 要找到这个数据源加载进去的 呀
jjqibmbld1 2008-04-10
  • 打赏
  • 举报
回复
继续等待
haizixf 2008-04-10
  • 打赏
  • 举报
回复
交流,成长我们,呵呵
jjqibmbld1 2008-04-09
  • 打赏
  • 举报
回复
就没人知道吗?我在网上查了很多资料,也是没人解决的了啊
jjqibmbld1 2008-04-09
  • 打赏
  • 举报
回复
哎,配置了也不行啊!
还特奇怪
这段程序放在页面就能运行
<%@ page contentType="text/html;charset=gb2312"%>
<%@ page import="java.sql.*"%>
<%@ page import="javax.sql.*"%>
<%@ page import="javax.naming.*"%>
<%!
final String JNDINAME = "java:comp/env/jdbc/teach" ;
%>
<%
Connection conn = null ;
try
{
// 初始化查找命名空间
Context ctx = new InitialContext() ;
// 找到DataSource
DataSource ds = (DataSource)ctx.lookup(JNDINAME) ;
conn = ds.getConnection() ;
}
catch(Exception e)
{
System.out.println(e) ;
}
%>
<%=conn%>
<%
// 将连接重新放回到池中

%>

可是把它改成类现在main中就不能运行了
wa7806 2008-04-09
  • 打赏
  • 举报
回复
web.xml中没有配置。
<resource-ref>
<description>jdbc/teach</description>
<res-ref-name>jdbc/teach</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
jjqibmbld1 2008-04-09
  • 打赏
  • 举报
回复
用jdbc是没错的!
fuzhao918 2008-04-09
  • 打赏
  • 举报
回复
你先用Jdbc连一下看看hibernate报错不?如果没错就是数据源配错了
<session-factory>
<property name="connection.url"></property>
<property name="connection.username"></property>
<property name="connection.password"></property>
<property name="connection.driver_class"></property>
<property name="dialect">org.hibernate.dialect.SQLServerDialect</property>

<mapping resource="jjq/vo/Institute.hbm.xml" />
</session-factory>

67,538

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧