在jboss里面部署会话bean总失败,查了很多资料,也按照那样做了,还是不行,望各位给我指点一下,分不够在加。 
我使用的sql2000数据库,想利用bean创建一个person表,然后对表里添加记录。 
我的工具配置如下: 
jboss 4.2.2,  myeclips 5.0 ,,jdk 1.5.0 我是这样做的: 
1,先在..jboss\server\default\lib 里面添加sqlserver的驱动,是三个文件,(msbase.jar,mssqlserver.jar,msutil.jar),启动jboss服务器没有异常。 
2,然后,在..jboss\server\default\deploy里面添加sqlserver的数据源文件,mssql-ds.xml,里面的内容是这样的 
<datasources> 
  <local-tx-datasource> 
    <jndi-name>MSSQLDS </jndi-name> 
    <connection-url>jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=foshanshop </connection-url> 
    <driver-class>com.microsoft.sqlserver.jdbc.SQLServerDriver </driver-class> 
    <user-name>sa </user-name> 
    <password>123456 </password> 
      <metadata> 
        <type-mapping>MS SQLSERVER2000 </type-mapping> 
      </metadata> 
  </local-tx-datasource> 
数据源 的jndi 为 mssqlds ,数据库用户名是sa,密码是123456;数据库名是foshanshop; 
重启jboss服务器没有异常。 
3,最后在把做好的ejb里面配置 persistence.xml ,文件内容如下: 
<?xml version="1.0"?> 
<persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" version="1.0"> 
  <persistence-unit name="foshanshop"> 
    
    <jta-data-source>java:/MSSQLDS </jta-data-source> 
    <properties> 
    <property name="hibernate.hbm2ddl.auto" value="create-drop"/> 
    <property name="hibernate.dialect" value="org.hibernate.dialect.SQLServerDialect"/>
    <!-- 调整JDBC抓取数量的大小: Statement.setFetchSize() --> 
    <property name="hibernate.jdbc.fetch_size" value="18"/> 
    <!-- 调整JDBC批量更新数量 --> 
    <property name="hibernate.jdbc.batch_size" value="10"/> 
    <!-- 显示最终执行的SQL --> 
    <property name="hibernate.show_sql" value="true"/> 
    <!-- 格式化显示的SQL --> 
    <property name="hibernate.format_sql" value="true"/> 
    </properties> 
  </persistence-unit> 
</persistence> 以上配置都正确吧???反正我认为是正确的,要是不对的话,大家给我指出来 
4,把ejb打包成jar文件,放在..jboss\server\default\deploy下面。 
最后重启jboss服务器,,我就日,它就出错了。。 
服务器报错信息,no classloader found for:com.microsoft.sqlserver.jdbc.sqlserverdriver
然后运行jsp 页面的时候,显示javax.persistence.PersistenceException: org.hibernate.exception.GenericJDBCException: Cannot open connection 
着到底是为什么?? 

解决方案 »

  1.   

    你应该在自己工程底下。在与SRC同及目录下新建一个lib目录。然后把驱动包拷贝到LIB下面。然后你再在工程里面引用导入的驱动包。刷新工程后,新建一个测试类,在类里,你试试这样写:import com.microsoft.sqlserver.jdbc.sqlserverdriver;
    还有,你的这个类名写错了。应该是:com.microsoft.sqlserver.jdbc.SqlserverDriver;类名怎么可能是小写开头呢?
      

  2.   

    <persistence-unit name="foshanshop" transaction-type="JTA">  试试!
      

  3.   

    简单你的JDBC驱动包没放进来啊,或者你com.microsoft.sqlserver.jdbc.SqlserverDriver这个写错了啊
      

  4.   

     <persistence-unit name="foshanshop"> 
    这里面 name 的值是你的EJB 的名称,不知道你写对没!配对了的话,你的项目中是不是没有引入JDBC驱动包!
      

  5.   

    你说的放进来,是放到项目里面吗??这个我已经放到服务器的jboss\server\default\lib里面了,还要怎么样放到里面??能说详细点,好吗?
      

  6.   

    你说的放进来,是放到项目里面吗??这个我已经放到服务器的jboss\server\default\lib里面了,还要怎么样放到里面??能说详细点,好吗?