【宏观思路】
小编最近正在进行Hibernate框架的学习,根据代码建立数据库表实现了一个小例子,跟读者朋友进行分享。下面是整体的思路过程:
1、创建java项目
2、创建User Library,加入依赖包
HIBERNATE_HOME/lib/*.jar
HIBERNATE_HOME/hibernate3.jar
加入数据库驱动(mysql驱动)
3、提供hibernate.cfg.xml文件,完成基本的配置
4、建立User.java实体类
5、提供User.hbm.xml文件,完成实体类的映射
6、将User.hbm.xml文件,加入到hibernate.cfg.xml文件中
7、编写工具类ExoprtDB.java,将hbm生成ddl,也就是hbm2ddl(在里面写main方法执行)
【代码实现】
一、用开发工具建立一个java项目三、hibernate.cfg.xml文件代码(配置数据库连接)
-
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 数据库连接配置 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_first</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123456</property>
<property name="hibernate.dialect">org.hibernate.dialect.MckoiDialect</property>
<!-- 与用户表配置文件对应的配置 -->
<mapping resource="com/bjpowernode/hibernate/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
-
四、User.java实体类代码(创建表对应的类对象)
-
package com.bjpowernode.hibernate;
import java.util.Date;
/**
* 用户表对应的类
* @author mk
*
*/
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) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public Date getCreateTime() {
return createTime;
}
public void setCreateTime(Date createTime) {
this.createTime = createTime;
}
public Date getExpireTime() {
return expireTime;
}
public void setExpireTime(Date expireTime) {
this.expireTime = expireTime;
}
}
-
五、User.hbm.xml文件代码(创建实体类映射)
-
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping >
<!-- 用户表对应的配置内容 -->
<class name="com.bjpowernode.hibernate.User">
<!-- 主键的配置 -->
<id name="id">
<generator class="uuid"/>
</id>
<property name="name"/>
<property name="password"/>
<property name="createTime"/>
<property name="expireTime"/>
</class>
</hibernate-mapping>
-
六、将User.hbm.xml文件,加入到Hibernate.cfg.xml文件中(配置实体类映射配置文件的链接)
-
package com.bjpowernode.hibernate;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
/**
* 将hbm生成ddl
* @author mk
*
*/
public class ExoprtDB {
public static void main(String[] args) {
//默认读取hibernate.cfg.xml文件
Configuration cfg = new Configuration().configure();
SchemaExport export = new SchemaExport(cfg);
//调用如下方法创建表
export.create(true, true);
}
}
-
注: 执行的时候需要先建立一个数据库,并且确保以上第三步配置是自己本计算机的信息配置
【总结】
没有接触的时候,觉得根据代码来创建数据库表,以及对应的字段类型是那么高大上的一件事情;当自己了解做过之后,的确发现很高大上但是依然觉得理解不够透彻;当自己总结完之后,发现理解的到位一些了,不过还是需要在将来以后的项目中不断锻炼才能得到最本质的理解。很期待后面的深入理解,从各种层次各种角度来理解O(∩_∩)O~