Spring3.x 接上篇 自动添加表实现

本文介绍了一种通过修改配置文件及添加SQL脚本实现自动创建数据库表的方法,并详细说明了具体步骤,包括配置hibernate属性、创建SQL文件及逆向工程配置文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

回去好好弄了下,终于找到一个自动添加表的方式,但是仍然有弊端

1、将applicationContext.xml文件中的

<bean id="hibernateProperties"
		class="org.springframework.beans.factory.config.PropertiesFactoryBean">
		<property name="properties">
			<props>
				<prop key="hibernate.hbm2ddl.auto">none</prop>
				<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</prop>
				<prop key="hibernate.query.substitutions">true 'T', false 'F'</prop>
				<prop key="hibernate.show_sql">false</prop>
				<prop key="hibernate.connection.autocommit">false</prop>
			</props>
		</property>
	</bean>
中红线标出的进行修改成:

<prop key="hibernate.hbm2ddl.auto">create</prop>
2、添加sql文件要求位置:添加文件夹-resource放到javaResource之下与src齐平

在resource文件夹下添加aiqtest.sql

内容如下:

use mysql;

CREATE DATABASE IF NOT EXISTS aiqtest default charset=utf8;
create user root identified by 'root';
flush privileges;

use aiqtest;
charset utf8;


CREATE TABLE student (
	id		bigint		AUTO_INCREMENT PRIMARY KEY ,
	name	VARCHAR(10)	NOT NULL ,
	age     INT	NOT NULL ,
	gender	BOOLEAN		NOT NULL ,
	birthday	DATE ,
	score 	DOUBLE NOT NULL
);
然后在同文件夹下添加文件--hibernate.reveng.xml

内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-reverse-engineering PUBLIC "-//Hibernate/Hibernate Reverse Engineering DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-reverse-engineering-3.0.dtd" >

<hibernate-reverse-engineering>
	<type-mapping>
		<sql-type jdbc-type="VARCHAR" hibernate-type="string"></sql-type>
	</type-mapping>
	<table-filter match-name="student"></table-filter>
</hibernate-reverse-engineering>
3、重启服务器---会自动创建表,但是好像不能自动创建库,这个时候没办法啦,只能自己创建库了(杯具--------)

求高手给予答复,谢谢指教


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值