【宏观思路】
小编最近正在进行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文件中(配置实体类映射配置文件的链接)
七、建立main方法,调用生成对应的表
- 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~