hibernate正向工程生成数据库
hibernate.cfg.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
<? xml version = '1.0' encoding = 'UTF-8' ?>
<! DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools. --> < hibernate-configuration >
< session-factory >
<!-- 指定连接数据库所用的驱动 -->
< property name = "connection.driver_class" >com.mysql.jdbc.Driver</ property >
<!-- 指定连接数据库的url,hibernate连接的数据库名 -->
< property name = "connection.url" >jdbc:mysql://localhost:3306/wsnsp</ property >
< property name = "connection.useUnicode" >true</ property >
< property name = "connection.characterEncoding" >gbk</ property >
<!-- 指定连接数据库的用户名 -->
< property name = "connection.username" >root</ property >
<!-- 指定连接数据库的密码 -->
< property name = "connection.password" >1111</ property >
<!-- 指定数据库方言 -->
< property name = "dialect" >org.hibernate.dialect.MySQL5InnoDBDialect</ property >
<!-- 根据需要自动创建数据库 -->
< property name = "hbm2ddl.auto" >create</ property >
<!-- 显示Hibernate持久化操作所生成的SQL -->
< property name = "show_sql" >true</ property >
<!-- 将SQL脚本进行格式化后再输出-->
< property name = "hibernate.format_sql" >true</ property >
<!-- 罗列所有的映射文件-->
< mapping resource = "ty/change/wsn/entity/Coordinator.hbm.xml" />
< mapping resource = "ty/change/wsn/entity/EndDevice.hbm.xml" />
< mapping resource = "ty/change/wsn/entity/Router.hbm.xml" />
< mapping resource = "ty/change/wsn/entity/User.hbm.xml" />
< mapping resource = "ty/change/wsn/entity/ZigBeeNode.hbm.xml" />
</ session-factory >
</ hibernate-configuration >
|
CreateDB.java
1
2
3
4
5
6
7
8
9
10
11
12
13
|
package
import
import
public CreateDB {
public static void
//装载配置文件
Configuration cfg = new Configuration().configure();
SchemaExport export = new SchemaExport(cfg);
export.create( true , true );
}
} |
运行CreateDB.java即可。
第一次运行程序时,将Hibernte中的hibernate.hbm2ddl.auto设置成create,让Hibernate帮助自动建表,但不成功,报了如下信息:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'type=InnoDB' at line 1。
后来,网上查找一番,发现是因为type=InnoDB在5.0以前是可以使用的,但5.1之后就不行了。如果我们把type=InnoDB改为engine=InnoDB就不会有这个问题。但是,我想使用Hibernate,自动帮我建表,怎么办呢。这就与我们指定的数据库方言(dialect)有关了。
之前我的配置是:
1
|
< prop key = "hibernate.dialect" >org.hibernate.dialect.MySQLInnoDBDialect</ prop >
|
现在改为:
1
|
< prop key = "hibernate.dialect" >org.hibernate.dialect.MySQL5InnoDBDialect</ prop >
|
好了,这样问题就解决了。总结下:
Using
'MySQL5InnoDBDialect'
works with
5.1
and
5.5
.
如果没有hbm.xml映射文件,而采用的是hibernate annotation方式,并且有hibernate配置文件cfg,只需要将hibernate.cfg.xml:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
< strong ><? xml version = '1.0' encoding = 'utf-8' ?>
<! DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
< hibernate-configuration >
< session-factory >
<!-- hibernate配置 -->
< property name = "connection.driver_class" >com.mysql.jdbc.Driver</ property >
< property name = "connection.url" >jdbc:mysql://localhost:3306/db_shome</ property >
< property name = "connection.username" >root</ property >
< property name = "connection.password" >1111</ property >
< property name = "dialect" >org.hibernate.dialect.MySQLDialect</ property >
< property name = "hibernate.connection.pool.size" >20</ property >
< property name = "show_sql" >true</ property >
< property name = "hbm2ddl.auto" >create</ property >
< property name = "current_session_context_class" >thread</ property >
< mapping class = "com.java1234.model.User" />
< mapping class = "com.java1234.model.Grade" />
< mapping class = "com.java1234.model.Student" />
</ session-factory >
</ hibernate-configuration ></ strong >
|
注意:
1
|
< strong >< property name = "hbm2ddl.auto" >create</ property ></ strong >
|
在数据库中新建对应的数据库名,启动工程后查询数据库(比如登录验证用户名密码)就可以生成数据库表了
hibernate正向工程生成数据库的更多相关文章
-
懒要懒到底,能自动的就不要手动,Hibernate正向工程完成Oracle数据库到MySql数据库转换(含字段转换、注释)
需求描述 需求是这样的:因为我们目前的一个老项目是Oracle数据库的,这个库呢,数据库是没有注释的,而且字段名和表名都是大写风格,比如 在代码层面的po呢,以前也是没有任何注释的,但是经过这些年,大 ...
-
Hibernate正向工程(实体类-->;数据库)
1,新建实体类News.java package com.hanqi.dao; import java.util.Date; public class News { private Integer i ...
-
eclipse下如何使用Hibernate反转工程生与数据库对应的实体类和映射文件(以MySQL为例)
首先需要为eclipse添加对Hibernate的支持(也就是下载的Hibernate中的jar包),下载方法另查,这里不多做阐述. 想要使用反转工程,首先要下载Hibernate反转工程的插件Jbo ...
-
hibernate+mysql 自动生成数据库问题
Hibernate Entity类 表名注解大写时,在windows下mysql自动生成的表都为小写(不区分大小写),在linux下mysql自动生成区分大小写.导致数据库问题. 原因(window下 ...
-
hibernate通过配置文件生成数据库信息
hibernate可以通过配置文件在数据库生成相应的数据库信息.也可以把数据库的信息生成相应的代码(实体类操作类和映射文件) 下面是通过代码默认对hibernate.cfg.xml信息在数据库生成信息 ...
-
powerDesigner 正向工程生成sql注释
找到script-->objects-->column-->add value内容如下: %:COLUMN% %:DATATYPE%[.Z:[%Compressed%? compre ...
-
hibernate笔记--通过SchemaExport生成数据库表
方法比较简单,项目中只需要两个java类(一个实体类,如User,一个工具类),两个配置文件(hibernate必须的两个配置文件hibernate.cfg.xml,与User.hbm.xml),即可 ...
-
用eclipes 添加jboss tools中的hibernate tool进行反向工程生成数据库对应的BOJO(Javabean)
用eclipes 添加jboss tools中的hibernate tool进行反向工程生成数据库对应的BOJO(Javabean) 安装: 在help中eclise marksplace中查询JBo ...
-
Hibernate 由实体类与配置文件的配置关系生成数据库中的表
import org.hibernate.cfg.Configuration; import org.hibernate.tool.hbm2ddl.SchemaExport; public class ...
随机推荐
-
谈谈Runtime类中的freeMemory,totalMemory,maxMemory等几个方法
最近在网上看到一些人讨论到java.lang.Runtime类中的freeMemory(),totalMemory(),maxMemory ()这几个方法的一些问题,很多人感到很疑惑,为什么,在jav ...
-
JDK、Eclipse、Myeclipse、Tomcat等各种软件的版本详解(写给对版本和兼容性问题焦头烂额的你)
这篇文章我们来探讨一下关于JDK.Eclipse.Myeclipse.Tomcat的版本问题.一.关于版本的几个概念1.32位和64位两个版本: 简言之,64位的操作系统支持识别4G以上的内存条 ...
-
Nagios 监控系统架构
Nagios 监控系统架设全攻略 简介: Nagios 全名为(Nagios Ain’t Goona Insist on Saintood),最初项目名字是 NetSaint.它是一款免费的开源 IT ...
-
rabbitmq-cluster搭建
一.前期准备: 准备3台linux系统,配置好公司源,或者官网下载相应的网络源 1.条件:准备3台linux系统,确保能连到download.yunwei.edu 2.编写yum源下载脚本: #vim ...
-
python之路-----MySql操作三
mysql 概述 一.主要内容: 视图 create view name (select * from user where id>5); 触发器 函数 存储过程 索引 二.各模块详细说明 1. ...
-
Jenkins 随笔
window是 随笔 修改端口 : <arguments>-Xrs -Xmx256m -Dhudson.lifecycle=hudson.lifecycle.WindowsService ...
-
loj#2013. 「SCOI2016」幸运数字 点分治/线性基
题目链接 loj#2013. 「SCOI2016」幸运数字 题解 和树上路径有管...点分治吧 把询问挂到点上 求出重心后,求出重心到每个点路径上的数的线性基 对于重心为lca的合并寻味,否则标记下传 ...
-
ionic toggle点击返回true/false支持自定义
<ul class="list"> <li class="item item-toggle"> 手机提醒 <label class ...
-
IDEA如何初始化Git本地仓库,并提交到远程仓库
本文转载自:http://blog.csdn.net/two_people/article/details/77008593 1. 首先在远程仓库上新建一个项目,码云和github都可以,我这里使用的 ...
-
SQLAlchemy-方言(Dialects)
一: Dialects 文档是分为三个部分: SQLAlchemy ORM, SQLAlchemy Core, and Dialects. SQLAlchemy ORM:在SQLAlchemy ORM ...