使用Hibernate导出schema到数据库的问题

wilderwang 2006-04-16 12:13:19
用ant hibernate生成数据库

返回的错误为

hibernate:

[schemaupdate] log4j:WARN No appenders could be found for logger (org.hi
bernate.

cfg.Environment).

[schemaupdate] log4j:WARN Please initialize the log4j system properly.

BUILD FAILED

I:\Program\J2EE\aib\workspace\company\build.xml:382: Schema text failed:
JDBC Driver class not found:

build.xml的相关部分为

<!-- Hibernate -->



<target name="hibernate" if="Hibernate"

description="Generating DB schema using Hibernate">



<taskdef name="schemaupdate"

classname="org.hibernate.tool.hbm2ddl.SchemaUpdateTask"

classpathref="class.path"/>



<schemaupdate

config="${hibernate.cfg.file}"

quiet="no">

</schemaupdate>



<taskdef name="schemaexport"

classname="org.hibernate.tool.hbm2ddl.SchemaExportTask"

classpathref="class.path"/>

<schemaexport

config="${hibernate.cfg.file}"

quiet="no"

text="no"

drop="no"

delimiter=";"

output="${root}/hibernate-schema-export.sql">

</schemaexport>

</target>



mysql的jdbc驱动已经装好,自己写代码连数据库也没问题

请问这有可能是什么方面的问题?
...全文
291 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
interpb 2006-04-16
  • 打赏
  • 举报
回复
class.path 的值是?
wilderwang 2006-04-16
  • 打赏
  • 举报
回复
大概是这样的,请问有什么问题?

<property name="classpath" value="${java.rt.file};${j2ee.jars};${axis.jars};${junit.jars};${jasper.jars};${xml.jars};${struts.jars};${jakarta.jars};${log4j.jars};${struts.jars};${xml.jars};${rm.jars};${hibernate.jars};.;${build}/classes;${db.jars};${hibernate.hbm.xml.dir};${portal.jars}"/>


<path id="class.path">
<pathelement path="${classpath}" />
<fileset dir="${dist}">
<include name="speedo.jar"/>
<include name="lib/log/log4j.jar"/>
<include name="lib/jdbc/*.jar"/>
</fileset>
</path>
Hibernate Tools for eclipse 创建Hibernate Console Configuration向导有Main、Option、Classpath、Mappings、Common五个选项卡,如果你在工程中已经引入了JDBC驱动则,直接点击Finish完成即可,以后在完成其他配置。 完成后,你就可以在Hibernate Configuration视图窗口看到配置项,已经链接到数据,并把你数据库中的表列出来,如果在这一步你没有成功的话,请检查你是否以正确安装的Hibernate Tools和JBoos Tools这个很重要;另外如果提示找不到JDBC驱动的话,说明你工程的classpath中没有JDBC驱动jar包,加载正确的驱动即可。 如果你不能看到上图所示的Hibernate Configurations窗口,说明你没有打开这个View,选择Windows-Show View-Other,然后选择Hibernate Configurations即可打开这个窗口,窗口的位置无关紧要,你喜欢放在那里就把他托过去。 下面将介绍如何使用Hibernate Code Generation来产生数据库表映射Java对象,首先要在数据库中创建表,并设置号字段名和主键(主键很重要,关于主键的选择建议你使用与业务无关的ID作为主键);打开Hibernate视图找到Hibernate运行图标下的Hibernate Code Generation Configurations,如果找不到这个图标说明没有在Hibernate视图下。 配置一个新的配置项,输入配置项的名称MyHibernateCode,选择Hibernate Configuration(即已配好的Hibernate控制台配置),在Output directory中输入反向代码输出目录(注意这个目录一般只需项目的源代码src),然后复选Reverse engineer from JDBC connection,在Package中输入包名(你要存放到src下那个包中),最后单击Setup-Create New打开Reverse engineer配置向导,选择配置存储位置(我放到了src目录下),最后选择要反向工程的表,如图; 如果你的Database schema中没有项目,查看你选择Console configuration是否正确,单击下面“Refresh”应该就出来了,最后单击Finish完成返回, 然后单击Exporters选项卡,选择导出项目,这里选择了Domain code(.java) 和Hibernate XML Mappings(.hbm.xml),因为使用的JDK版本较高因此复选Use Java 5 syntax项。Refresh和Common项可不进行设置,最后单击Run运行,产生代码。 产生的代码和配置文件,如图示;代码自动产生后还需要你根据自己的业务逻辑检查一下,并按你的DAO架构完成,Hibernate Tools到这里已经帮你完成的大量编码工作。 【编辑推荐

67,513

社区成员

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

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