1.点击Myecplise右上角
2.点击进入后,在这个区域右键 New 一个新的connection
3.以mySql连接为例子,在这里展示一下,下面这几项必须都要按照要求完全一致,除了架包所在的本地位置之外
4.配置完成可以点击上图的Test Driver,测试是否连接成功。连接成功的界面如下:
5.选择本数据库下的所有数据表或者你自己想要生成实体的数据表,点击反向生成
6.此刻,如果在选择的项目中没有我们想要操作的项目,说明我们的项目此时还不支持hibernate,还不是hibernate项目,那我们需要先回到正常的myEcplise界面下,将我们的项目转成hibernate项目
我们需要指定Hibernate的映射文件还有sessionFactory的包名,因为他们不能被创建在默认的包中,下面的提示很清楚
处理完成之后,我们的项目就支持hibernate了。这个时候我们就可以再进入到
这个界面下面接着进行我们的操作了。
7.我们 连接上我们的数据库,然后,选择所有的数据表,反向生成点击:
然后进入这个界面,我们选择如下:【我们采用注解的形式,就不选择映射文件的方式了】
普通的ID生成就是下面这样,不用修改什么。
如果想要规定主键的生成策略,例如主键生成策略为uuid,则本页面可以如下【如果之前实体已经生成,不用怕,这个可以覆盖生成】:
8.然后回到正常的界面,查看项目结构,发现项目已经正常生成实体了
查看实体中的内容发现:不仅实体,实体与实体之间的关系也都正常的生成【我们是5个数据表,但是这个例子中有两个多对多生成的中间表,hibernate反向工程会自动的将这两个中间表变作ManyToMany的关系存在于实体中!!】
package com.it.entity; import java.util.HashSet;
import java.util.Set;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.ManyToMany;
import javax.persistence.Table; /**
* Authority entity. @author MyEclipse Persistence Tools
*/
@Entity
@Table(name = "authority", catalog = "testdb")
public class Authority implements java.io.Serializable { // Fields private String authorityId;
private String authorityName;
private Set<Role> roles = new HashSet<Role>(0); // Constructors /** default constructor */
public Authority() {
} /** minimal constructor */
public Authority(String authorityId) {
this.authorityId = authorityId;
} /** full constructor */
public Authority(String authorityId, String authorityName, Set<Role> roles) {
this.authorityId = authorityId;
this.authorityName = authorityName;
this.roles = roles;
} // Property accessors
@Id
@Column(name = "authorityId", unique = true, nullable = false, length = 36)
public String getAuthorityId() {
return this.authorityId;
} public void setAuthorityId(String authorityId) {
this.authorityId = authorityId;
} @Column(name = "authorityName", length = 50)
public String getAuthorityName() {
return this.authorityName;
} public void setAuthorityName(String authorityName) {
this.authorityName = authorityName;
} @ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "authorities")
public Set<Role> getRoles() {
return this.roles;
} public void setRoles(Set<Role> roles) {
this.roles = roles;
} }
错误1:
The last packet successfully received from the server was 0 milliseconds ago.
解决方法:
检查你的每一项的单词拼写是否有误,然后在URL上添加:?autoReconnect=true
例如下:
错误2:
数据表之间有多对多的关系,然后应该是生成一张中间表就好,但是多生成一张ID表
如下图:
user表和testorder表生成一张中间表score
但是使用hibernate 反向生成tools后生成的实体如下:
多生成了一个ScoreId表
解决方法:
将本张表中的两个主键设置为一个主键 即可解决这个问题:
这样就解决了 会多生成一个ID类的问题