java

位置:IT落伍者 >> java >> 浏览文章

八步详解Hibernate的搭建及使用


发布日期:2023年02月20日
 
八步详解Hibernate的搭建及使用
上篇博客已经把Hibernate概念和其中的核心接口介绍下面举个实例添加用户来介绍Hibernate如何使用

创建普通的java项目

因为Hibernate是一个轻量级的框架不像servlet还必须需要tomcat的支持Hibernate只要jdk支持即可

引入jar包

可以在项目中直接引入jar包项目>属性>然后如下图

另一种办法就是引入库相当于一个文件夹把所有的jar包放到自己新建的文件夹中窗体>选项>然后如下图

提供Hibernate的配置文件hibernatecfgxml文件完成相应的配置

<hibernateconfiguration>

<sessionfactory>

<property name=nnectiondriver_class>commysqljdbcDriver</property>

<property name=nnectionurl>jdbc:mysql://localhost:/hibernate_first</property>

<property name=nnectionusername>root</property>

<property name=nnectionpassword>bjpowernode</property>

<property name=hibernatedialect>orghibernatedialectMySQLDialect</property>

</sessionfactory>

</hibernateconfiguration>

在这里连接mysql数据库解释一下上面的标签按照顺序来依次解释第一个是连接mySql的驱动第二个是连接的url;url后面的hibernate_first是数据库名字第三个是和第四个分别是用户名和密码第五个是方言因为 hibernate对数据库封装对不同的数据库翻译成不同的形式比如drp中的分页若是使用oracle数据库则翻译成sql语句三层嵌套若是使用mySql数据库则翻译成limit语句

建立实体User类

package combjpowernodehibernate;

import javautilDate;

public class User {

private String id;

private String name;

private String password;

private Date createTime;

private Date expireTime;

public String getId() {

return id;

}

public void setId(String id)

{

thisid = id;

}

public String getName()

{

return name;

}

public void setName(String name)

{

thisname = name;

}

public String getPassword()

{

return password;

}

public void setPassword(String password)

{

thispassword = password;

}

public Date getCreateTime()

{

return createTime;

}

public void setCreateTime(Date createTime)

{

thiscreateTime = createTime;

}

public Date getExpireTime()

{

return expireTime;

}

public void setExpireTime(Date expireTime)

{

thisexpireTime = expireTime;

}

}

建立Userhbmxml此文件用来完成对象与数据库表的字段的映射也就是实体类的那些字段需要映射到数据库表中呢

<?xml version=?>

<!DOCTYPE hibernatemapping PUBLIC

//Hibernate/Hibernate Mapping DTD //EN

hiber/hibernatemappingdtd> <hibernatemapping>

<class name=combjpowernodehibernateUser>

<id name=id>

<generator class=uuid/>

</id>

<property name=name/>

<property name=password/>

<property name=createTime/>

<property name=expireTime/>

</class> </hibernatemapping>

我们也映射完毕了但是hibernate怎么知道我们映射完了呢以及如何映射的呢?这就需要我们把我们自己的映射文件告诉hibernate在hibernatecfgxml配置我们的映射文件

<mapping resource=com/bjpowernode/hibernate/Userhbmxml/>

生成数据库表大家也看到了我们上述还没有新建数据表呢在第三步我们只是新建了数据库而已按照我们普通的做法我们应该新建数据表啊否则实体存放何处啊这个别急数据库表这个肯定是需要有的这个毋庸置疑但是这个可不像我们原来需要自己亲自动手建立哦现在hibernate需要帮我们实现哦如何实现嗯hibernate会根据配置文件hibernatecfgxml和我们的映射文件Userhbmxml会自动给我们生成相应的表并且这个表的名字也给我们取好默认是User那如何生成表呢?

//默认读取hibernatecfgxml文件

Configuration cfg = new Configuration()configure()

SchemaExport export = new SchemaExport(cfg)

exportcreate(true true)

那我们就开始进行操作啦我们添加一个用户对象看看hibernate是如何添加的呢?跟我们以前的做法有什么不同呢?

public class Client {

public static void main(String[] args)

{

//读取hibernatecfgxml文件

Configuration cfg = new Configuration()configure()

//建立SessionFactory

SessionFactory factory = cfgbuildSessionFactory()

//取得session

Session session = null;

try {

session = factoryopenSession()

//开启事务

sessionbeginTransaction()

User user = new User()

usersetName(张三

usersetPassword(

usersetCreateTime(new Date())

usersetExpireTime(new Date())

//保存User对象

sessionsave(user)

//提交事务

sessiongetTransaction()commit()

}catch(Exception e) {

eprintStackTrace()

//回滚事务

sessiongetTransaction()rollback()

}finally {

if (session != null)

{

if (sessionisOpen())

{

//关闭session

sessionclose()

}

}

}

}

}

第八步我们可以看到没有我们熟悉的insert into表的sql语句了那怎么添加进去的呢到底添加了没?让我真实滴告诉你确实添加进去了不信的可以自己尝试哦这也是hibernate的优点对jdbc封装的彻底减少了我们对数据的操作时间哈

这就是真切滴介绍了hibernate的基本用法其中好多优点等待我们自己去发现哦比如hibernate中的缓存机制映射方案哦

               

上一篇:两个加速Eclipse流行的插件介绍

下一篇:介绍下Eclipse中如何debug程序?