在实际开发中,一般都是表结构先设计好,再实现代码,所以根据表结构生成数据库实体类比较常见。说不如做,行动吧。
创建表
CREATE TABLE [dbo].[Classes](
[class_id] [int] IDENTITY(1,1) NOT NULL,
[name] [varchar](50) NULL,
[create_time] [datetime] NULL,
CONSTRAINT [PK_Classes] PRIMARY KEY CLUSTERED
(
[class_id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON
创建Console Configuration
New->选择Console Configuration->Next:
检查下Hibernate版本,项目,数据库,配置文件。点确定后就是下图:
可能有些人没有这个视图,打开Window->Show View->Other->Hibernate->Hibernate Configuration就可以看到那个视图了。
创建反向工程配置文件
这个文件也可以在启动生成代码的时候选择创建。但是我还是先创建好放心些。
next
next
选择console configuration,refresh,选择要生成代码的表。
至此hibernate.reveng.xml文件已经创建,但是我们需要做些配置,默认的可能不太合适。
打开reveng.xml文件,切换到下图:
如果顺利的话,点击“Add”会弹出数据库库让你选择。如果有多个console configuration会先提示让选择一个。
可是可是我不顺利啊,选择了console configuration之后什么反应都没有。于是我开始各种折腾:
折腾1:修改console configuration的hibernate版本为5.0以下。居然可以生成代码了,激动,可是代码报错。
折腾2:升级eclipse版本,这个是我灵光一闪觉得可能是我的hibernate版本太高了,hibernate tools不支持,可是hibernate tools可是跟着eclipse走的。下载中。。。。下载了Mar2版本不可以安装Jboss tools 4.4.0,下载了Neon版本,天啊噜,看到Jboss tools 4.4.0了,心里又是一阵激动。可惜安装不成功,反复了几次,姐不干了,准备第二天再试(ps:之前就碰到过当天安装不成功的,改天就行了,怀疑网络问题)。第二天一早我就开始重新安装Jboss tools,good,成功了,成功了,不仅安装成功,也可以添加Tables,下图可以见证我的成功:
我又开始激动的准备生成代码了。
看不到这个按钮,没关系,没关系,从window->Perspetive打开,如下图:
回到正题,开始配置运行生成代码的相关配置:
Run起来,代码出来了:
配置cfg.xml
代码是生成了,跟数据库的映射关系也有了,可是hibernate不知道映射文件在哪啊,有必要告诉一声,修改cg.xml,添加下面配置,当然用工具添加更简单:
<mapping resource="Classes.hbm.xml"/>
我把Classes.hbm.xml拉倒resources文件下,所以跟cfg.xml是一个目录,实际情况文件在哪就配置相应的路径即可。
修改LoginAction
public String execute() throws Exception {
Session ss = getSession();
ss.beginTransaction();
/*ss.save(PersonShana);
ss.getTransaction().commit();*/
Classes classes = new Classes();
classes.setName("语文");
classes.setCreateTime(new Date());
ss.save(classes);
ss.getTransaction().commit();
ss.close();
return "success";
}
static Session getSession() {
if (sessionFactory == null) {
final StandardServiceRegistry registry = new StandardServiceRegistryBuilder().configure().build();
sessionFactory = new MetadataSources(registry).buildMetadata().buildSessionFactory();
}
return sessionFactory.openSession();
}
运行
打开http://localhost:8080/webtest/login
数据库有数据啦。