how2j.cn

步骤 1 : 自动生成表结构   
步骤 2 : 自动生成表结构 失效的处理   

步骤 1 :

自动生成表结构

edit
在applicationContext.xml的sessionFactory中配置了有

<property name="hibernateProperties">
<value>
hibernate.dialect=org.hibernate.dialect.MySQLDialect
hibernate.show_sql=false
hbm2ddl.auto=update
</value>
</property>

其中hbm2ddl.auto=update就表示是自动更新表结构,不需要手段创建的变更。
步骤 2 :

自动生成表结构 失效的处理

edit
但是有的时候,会失效,不能够自动生成表结构。
需要在sessionfactory中加这么一句:

<property name="schemaUpdate">
<value>true</value>
</property>

即可使用
<bean name="sf" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="ds" /> <property name="mappingResources"> <list> <value>com/pojo/Admin.hbm.xml</value> </list> </property> <property name="schemaUpdate"> <value>true</value> </property> <property name="hibernateProperties"> <value> hibernate.dialect=org.hibernate.dialect.MySQLDialect hibernate.show_sql=false hbm2ddl.auto=update </value> </property>
 	 <bean name="sf"
        class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <property name="dataSource" ref="ds" />
        <property name="mappingResources">
            <list>
            	<value>com/pojo/Admin.hbm.xml</value>
            </list>
        </property>
	    <property name="schemaUpdate">  
	        <value>true</value>  
	    </property>          
        <property name="hibernateProperties">
            <value>
                hibernate.dialect=org.hibernate.dialect.MySQLDialect
                hibernate.show_sql=false
                hbm2ddl.auto=update
            </value>
        </property>


HOW2J公众号,关注后实时获知最新的教程和优惠活动,谢谢。


问答区域    
2019-07-09 求助:自动建表失败,哪位骚年帮忙分析分析啊
biteme




用的mysql-connector是8.0版本的。
<bean name="sf" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
		<property name="dataSource" ref="ds"></property>
		<property name="mappingResources">
			<list>
				<value>st/pojo/Product.hbm.xml</value>
			</list>
		</property>
		<property name="schemaUpdate">
			<value>true</value>
		</property>
		<property name="hibernateProperties">
			<value>
				hibernate.dialect=org.hibernate.dialect.MySQLDialect
				hibernate.show_sql=true
				hbm2ddl.auto=update
			</value>
		</property>
	</bean>
	
	<bean name="ds" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
		<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"></property>
		<property name="url" value="jdbc:mysql://localhost:3306/how2java?useSSL=false&amp;serverTimezone=UTC"></property>
		<property name="username" value="root"></property>
		<property name="password" value="123456"></property>
	</bean>
第一个异常:org.hibernate.exception.SQLGrammarException: could not execute query
第二个异常:java.sql.SQLSyntaxErrorException: Table 'how2java.product_' doesn't exist


4 个答案

丹心
答案时间:2022-12-19
可能是你的mysql-connector版本不对,你换成5.0的试一试

biteme
答案时间:2019-07-13
hbm2ddl.auto=update改成hibernate.hbm2ddl.auto=update也试过了,没效果啊,至于是不是因为查询时表不会自动建就不知道了

枭十二
答案时间:2019-07-12
而且你这错误是因为执行查询时表不存在,好像查询时表不会自动建,添加数据时才会自动建表

枭十二
答案时间:2019-07-12
把16行的 hbm2ddl.auto=update 改成 hibernate.hbm2ddl.auto=update 然后再试试



回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2017-10-07 关于自动更新表结构问题
iloveyou无望

表结构不是我们在数据库里面写的东西吗,加了这些代码是不是表示创建表结构的步骤由框架来完成?那框架又怎么会知道哪些要索引,哪些有主外键关系? <property name="schemaUpdate"> <value>true</value> </property> <property name="hibernateProperties"> <value> hibernate.dialect=org.hibernate.dialect.MySQLDialect hibernate.show_sql=false hbm2ddl.auto=update </value> </property>




1 个答案

慢慢强大
答案时间:2018-02-28
在hibernate配置文件中可以配置表与表之间的关联关系



回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到








提问之前请登陆
提问已经提交成功,正在审核。 请于 我的提问 处查看提问记录,谢谢
关于 JAVA 框架-SSH-自动生成表结构 的提问

尽量提供截图代码异常信息,有助于分析和解决问题。 也可进本站QQ群交流: 578362961
提问尽量提供完整的代码,环境描述,越是有利于问题的重现,您的问题越能更快得到解答。
对教程中代码有疑问,请提供是哪个步骤,哪一行有疑问,这样便于快速定位问题,提高问题得到解答的速度
在已经存在的几千个提问里,有相当大的比例,是因为使用了和站长不同版本的开发环境导致的,比如 jdk, eclpise, idea, mysql,tomcat 等等软件的版本不一致。
请使用和站长一样的版本,可以节约自己大量的学习时间。 站长把教学中用的软件版本整理了,都统一放在了这里, 方便大家下载: https://how2j.cn/k/helloworld/helloworld-version/1718.html

上传截图