首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > Java Web开发 >

spring与hibernate整合的时候怎么在控制台上输出建表语句

2012-05-20 
spring与hibernate整合的时候如何在控制台上输出建表语句只用hibernate的时候可以用new SchemaExport(new

spring与hibernate整合的时候如何在控制台上输出建表语句
只用hibernate的时候可以用new SchemaExport(new Configuration().configure()).create(true, true);方式
但是现在整合了spring之后,没有了hibernate.cfg.xml文件
原本都内容都放到了beans.xml中,以及采用hibernate加注解的方式实现
也就没有了new Configuration().configure()
网上有个帖子说是配置在beans.xml中的sessionFactory继承自某个类,然后那个类有getConfigure()方法
于是可以用SchemaExport的方式在控制台上输出建表语句

但是我在用的时候发现那些方法都是protected的 不可以被访问
不知道有没有同学遇到我这个需求,然后都是怎么解决的?

[解决办法]
个人建议,hibernate的配置文件最好从spring里提出来,这样方便管理
[解决办法]
show_sql设置为true
[解决办法]
显示sql语句show_sql 为true
格式化sql语句hibernate.format_sql 为true
hibernate.order_updates 为true
[解决办法]
显示sql语句show_sql 为true
设置hibernate.format_sql 为true
设置hibernate.order_updates 为true
[解决办法]
如果你用hibernat,

Java code
<!--  Hibernate Session Factory   --> - <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">- <property name="dataSource">  <ref bean="dataSource" />   </property>- <property name="hibernateProperties">- <props>  <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>   <prop key="hibernate.show_sql">true</prop>   <prop key="hibernate.hbm2ddl.auto">update</prop>   <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>   </props>  </property>- <!--  Spring機制,掃描<value>中 所有package.  --> - <property name="packagesToScan">- <list>  <value>com.cybersoft4u.xian.dmo.common</value>   <value>com.cybersoft4u.xian.dmo.privilege</value>   <value>com.cybersoft4u.xian.dmo.hr</value>   <value>com.cybersoft4u.xian.dmo.device</value>   </list>  </property>  </bean>
[解决办法]
XML code
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"> <property name="dataSource">  <ref bean="dataSource" />   </property> <property name="hibernateProperties"> <props>  <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>   <prop key="hibernate.show_sql">true</prop>   <prop key="hibernate.hbm2ddl.auto">update</prop>   <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>   </props>  </property><property name="packagesToScan"> <list>  <value>com.cybersoft4u.xian.dmo.common</value>   <value>com.cybersoft4u.xian.dmo.privilege</value>   <value>com.cybersoft4u.xian.dmo.hr</value>   <value>com.cybersoft4u.xian.dmo.device</value>   </list>  </property>  </bean> 

热点排行