【java】——Hibernate代码创建表

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u013030601/article/details/52516086

【宏观思路】

    小编最近正在进行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~
阅读更多
换一批

没有更多推荐了,返回首页