Java之旅hibernate(8)——基本关系映射

  何为关系,何为映射,关系这个词想必大家都不陌生。比方你和老师之间是师生关系,你和父母之间是父子或者父女(母子或者母女关系)。

  关系是存在某种联系物体之间产生的。什么都是可能的。比方你和工具,你仅仅能使用工具,可是工具不能使用你。这种关系是单向的。可是换种说法。你拥有工具,工具也属于你,那么这种关系就是双向的了,此外一个人能够拥有多个工具,而且多个工具也能够是属于一个人的。还有就是多个人拥有多个工具,而且多个工具也属于人,依据这些特征,我们将关系分为下面几种:

  单向关系:

  one2one,(一对一)

  many3one(多对一)

  one2many(一对多)

  many2many(多对多)

  双向关系:

  one2many(一对多)

  many2many(多对多)

  one2one(一对一)

 基本映射必备知识

  必须存在的文件和实体

  实体类(.java)

  实体类的存在是基础,由于我们要做的就是将实体类映射成为表,在映射之前先建好实体类,以及主键和各个属性字段。

代码例如以下图:

import java.util.Date;

public class User {

	private String id;

	private String name;

	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;
	}

  映射文件(*.hbm.xml)

  映射文件一般是以.hbm.xml为后缀的,比方我们建立一个User的实体,那么我们的映射文件就是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"/>
	</class>
</hibernate-mapping>

  Hibernate的配置文件(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_session</property>
		<property name="hibernate.connection.username">root</property>
		<property name="hibernate.connection.password">bjpowernode</property>
		<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
		<property name="hibernate.show_sql">true</property>

		<mapping resource="com/bjpowernode/hibernate/User.hbm.xml"/>
	</session-factory>
</hibernate-configuration>

  这里不只配置了数据库的信息,而且也配置了映射文件,从而能够通过工具类将映射文件导入到数据库。

  工具类

  这是我们自己手写的工具类。用于将实体类映射成表。并保存到数据库。

import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;

/**
 * 将hbm生成ddl
 * @author Administrator
 *
 */
public class ExportDB {

	public static void main(String[] args) {

		//默认读取hibernate.cfg.xml文件
		Configuration cfg = new Configuration().configure();

		SchemaExport export = new SchemaExport(cfg);
		export.create(true, true);
	}
}

 小结

  了解了上面的基本信息,那就便于我们对于hibernate的七种映射关系进行理解。以下的文章将进行hibernate七种关系的一一解说。

时间: 2024-09-30 07:03:45

Java之旅hibernate(8)——基本关系映射的相关文章

菜鸟学习Hibernate——一对多关系映射

Hibernate中的关系映射,最常见的关系映射之一就是一对多关系映射例如学生与班级的关系,一个班级对应多个学生.如图: Hibernate中如何来映射这两个的关系呢? 下面就为大家讲解一下: 1.创建实体类Classes和实体类Student Classes.java package com.bjpowernode.hibernate; import java.util.Set; public class Classes { private int id; private String nam

Hibernate多对多关系映射(建表)

下边讲述Hibernate多对多关系映射. 多对多关系的表的结构为: 两个实体表,还包含一个关系表,关系表为复合主键,如果要使用Hibernate多对多关系映射,则关系表必须只包含两个字段,如果生成了Hibernate多对多关系映射,则中间关系表不会生成实体(即没有对应的pojo类,更没有其映射文件). 1.建立表 DROP TABLE user_course ; DROP TABLE user ; DROP TABLE course ; CREATE TABLE user ( userid  

hibernate的对象/关系映射结果为空,exists查不到值的问题-20190823

1: hibernate的对象/关系映射 情景:在使用@onetotone/@manytonone时关联结果为空 原因:在使用这个注解的时候,默认的时crossjoin(交叉连接),在进行查询时以及排序时用到了注解关联的属性,如果这个属性为空就会导致查空 解决:注意关联过程中使用到的属性一定要存在 拓展: 1 @OneToOne(fetch = FetchType.LAZY)--懒加载2 @JoinColumns({ 3 @JoinColumn(name = "主键", referen

Hibernate之实体关系映射

延迟加载与即时加载 例如Person类和Email类是一对多关系,如果设为即时加载,当加载Person时,会自动加载Email,如果设置为延迟加载,当第一次调用person.getEmails()时才会执行SQL语句加载Email 注解配置时,@OnetToMany(Fetch = FetchType.EAGER)为即时加载,Fetch = FetchType.LAZY为延迟加载 延迟加载和即时加载的策略适用于所有一对多.多对一.多对多等所有的实体关系 一般来说,延迟加载要比即时加载节省资源,但

hibernate 多对多关系映射

学生 和 课程就是一种多对多的关系映射,那么再hibernate中,对于多对多关系在怎么配置? 和一些注意的事项?简单测试下. 建表 实体 配置文件和映射 测试 1.使用oracle ,建表sql create table students( id number(7) primary key,   name nvarchar2(20),   age number(2) ) create table course( id number(7) primary key,   name nvarchar

Java之旅hibernate(3)——第一个hibernate的样例

在解说样例之前.我们首先来理解一下hibernate的工作原理.理解原理将会帮助我们更好地理解hibernate和运用hibernate. 1.      原理图 利用hibernate进行数据的持久化操作,必定离不开与数据库打交道.依据上张图我们来看看hibernate是怎样工作的. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gra

Hibernate多对多关系映射

两张表的多对多关系,在数据库中通常是通过第三张中间表来实现的,第三张中间表放的是两张表各自的主键值,通过主键与主键的对应来体现表直接的关系.比如在权限系统中,一个用户可以拥有多种权限,而一种权限也可以授予多个用户. 在持久化对象设计的时候,角色和用户都分别有一个集合来防止拥有它的用户或角色.角色类的设计: public class RolePO { private int id;  private String name;  private Set employees = new HashSet

hibernate 一对多 关系映射

在关系中,或多或少的表之间有复杂的关联关系 这里测试 一对多 关联关系的配置 开发步骤就不多说了.直接看一个示例. users 用户 和  shop商品订单表 分析:一个用户可以有多个商品订单,一个订单只属于一个用户. 这样就构成了一对多的关联关系. 这里用的是oracle 数据库 users 和 shop 数据库表 create table users( id number(7) primary key,   name nvarchar2(20),   pass nvarchar2(20),

Java之旅hibernate(6)——Junit不为人知的故事

  说道Junit,我们首先不得不说測试的重要性.一个健壮的软件肯定是经过不断地的測试后才干终于被应用的.在測试的过程中能够发现非常多不稳定性或者说是存在一定的bug等等.这些都能够在測试阶段发现.而不会被推到被用户真正的使用的时候.避免了不良好的用户体验. 当我们看java源程序的时候.总是会看到这种一个目录,名字为test,好奇的你是否点开过呢? 没错,这里就是我们书写的測试程序,使得在团队开发过程中.彼此的交互更加的可靠和稳定. 那么Junti详细是什么呢? 1.       Junit