本文介绍了eclipse下搭建hibernate5.0环境的步骤,分享给大家,具体如下:
- hibernate引入的jar包:hibernate-release-5.0.12.final.zip
- 数据库驱动:mysql-connector-java-5.1.46
二.安装hibernate插件
打开eclipse,点击help-->eclipse marketplace,如图输入:hibernate tools,再点击goa按钮,找到jboss tools
点击install安装
如图选择hibernate tools,点击confrm安装。安装完成后重启eclipse。
三. 创建工程
1.创建新项目hibernatedemo,在工程下建立lib文件夹。打开jar包的目录,导入lib/required下的和数据库的jar包,add to build path
在src下新建文件
点击next,默认文件名,点击next,如图配置数据库信息
选择utf-8编码方式,点击finish,生成的hibernate.cfg.xml配置文件内容如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<?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> <property name= "hibernate.connection.driver_class" >com.mysql.jdbc.driver</property> <property name= "hibernate.connection.password" >a123</property> <property name= "hibernate.connection.url" >jdbc:mysql: //localhost:3306/tb_test</property> <property name= "hibernate.connection.username" >sherman</property> <property name= "hibernate.dialect" >org.hibernate.dialect.mysqldialect</property> </session-factory> </hibernate-configuration> |
注意,把 < session-factory name ="mysql" > 的name属性去掉,否则报org.hibernate.engine.jndi.jndiexception异常,在该文件中添加一些配置,如图:
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
|
<?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> <property name= "hibernate.connection.driver_class" >com.mysql.jdbc.driver</property> <property name= "hibernate.connection.password" >a123</property> <property name= "hibernate.connection.url" >jdbc:mysql: //localhost:3306/tb_test</property> <property name= "hibernate.connection.username" >sherman</property> <!-- 配置数据库方言 --> <property name= "hibernate.dialect" >org.hibernate.dialect.mysql5dialect</property> <!-- 控制台打印sql语句 --> <property name= "show_sql" > true </property> <!-- 格式化sql --> <property name= "format_sql" > true </property> <!--在启动时根据配置更新数据库 --> <property name= "hibernate.hbm2ddl.auto" >update</property> <!-- 配置连接池的连接数 --> <property name= "connection.pool_size" > 20 </property> <!-- 注册实体映射类 --> <mapping class = "com.gdut.app.entity.news" /> </session-factory> </hibernate-configuration> |
在src下新建一个包com.gdut.app.entity,存放持久化类news,news类代码如下
package com.gdut.app.entity;
import javax.persistence.entity;
import javax.persistence.generatedvalue;
import javax.persistence.generationtype;
import javax.persistence.id;
import javax.persistence.table;@entity
@table(name="news_info")
public class news {
@id
@generatedvalue(strategy=generationtype.identity)
private integer id;
private string title;
private string content;
public news() {
}
public news(integer id, string title, string content) {
this.id = id;
this.title = title;
this.content = content;
}
public integer getid() {
return id;
}
public void setid(integer id) {
this.id = id;
}
public string gettitle() {
return title;
}
public void settitle(string title) {
this.title = title;
}
public string getcontent() {
return content;
}
public void setcontent(string content) {
this.content = content;
}
@override
public string tostring() {
}
}
编写测试类:
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
|
package com.gdut.app.entity; import org.hibernate.session; import org.hibernate.sessionfactory; import org.hibernate.transaction; import org.hibernate.cfg.configuration; import org.junit.test; public class beantest { @test public void beantest() { // final standardserviceregistry serviceregistry = new standardserviceregistrybuilder() // .configure("hibernate.cfg.xml").build(); // // sessionfactory sf = new metadatasources(serviceregistry).buildmetadata().buildsessionfactory(); //两种方式都可以获取sessionfactory configuration cfg = new configuration().configure(); sessionfactory sf = cfg.buildsessionfactory(); session sess =sf.opensession(); transaction transaction = sess.begintransaction(); news n = new news(); n.setcontent( "在广工毕业" ); n.settitle( "毕业季" ); sess.save(n); transaction.commit(); sess.close(); } } |
经过测试成功
或者通过映射文件
在com.gdut.app.entity包下简历一个news.hbm.xml映射配置文件,修改genarator的class属性为active
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<?xml version= "1.0" ?> <!doctype hibernate-mapping public "-//hibernate/hibernate mapping dtd 3.0//en" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" > <!-- generated 2018 - 5 - 22 23 : 45 : 23 by hibernate tools 3.5 . 0 . final --> <hibernate-mapping> < class name= "com.gdut.app.entity.news" table= "news" > <id name= "id" type= "java.lang.integer" > <column name= "id" /> <generator class = "native" /> </id> <property name= "title" type= "java.lang.string" > <column name= "title" /> </property> <property name= "content" type= "java.lang.string" > <column name= "content" /> </property> </ class > </hibernate-mapping> |
在hibernate.cfg.xml中配置
1
|
<mapping resource= "com/gdut/app/entity/news.hbm.xml" /> |
测试验证成功。
整个工程架构如图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/yumiaoxia/p/9074904.html