eclipse学习(第三章:ssh中的Hibernate)——4.Hibernate中的映射文件及映射类型

前言

本文参考自https://www.w3cschool.cn/hibernate/1vlx1iej.html后做的笔记。

映射文件

一个对象/关系型映射一般定义在 XML 文件中。映射文件指示 Hibernate 如何将已经定义的类或类组与数据库中的表对应起来。
尽管有些 Hibernate 用户选择手写 XML 文件,但是有很多工具可以用来给先进的 Hibernate 用户生成映射文件。这样的工具包括 XDoclet, Middlegen 和 AndroMDA

映射示例

创建Teacher类

package com.czx.mapping;

public class Teacher {
	
	private Integer id;
	
	private String name;
	
	private String subject;
	
	private String favoriteFood;
	
	private Double height;

	public Integer getId() {
		return id;
	}

	public void setId(Integer id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getSubject() {
		return subject;
	}

	public void setSubject(String subject) {
		this.subject = subject;
	}

	public String getFavoriteFood() {
		return favoriteFood;
	}

	public void setFavoriteFood(String favoriteFood) {
		this.favoriteFood = favoriteFood;
	}

	public Double getHeight() {
		return height;
	}

	public void setHeight(Double height) {
		this.height = height;
	}

	public Teacher(Integer id, String name, String subject, String favoriteFood, Double height) {
		this.id = id;
		this.name = name;
		this.subject = subject;
		this.favoriteFood = favoriteFood;
		this.height = height;
	}

	public Teacher() {
	}

	
}

对应的数据库表结构

在这里插入图片描述

创建一个Teacher.hbm.xml

这个主要是用来将已定义的类或类组与数据库表匹配。
而且这个名称是有定义规则的。

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
	
<hibernate-mapping>
	<class name="Teacher" table="teacher">
		<meta attribute="class-description">
			一个Teacher类的描述
		</meta>
		
		<id name="id" column="id" type="integer">
			<generator class="native"></generator>
		</id>
		
		<property name="name" column="name" type="string"></property>
		<property name="subject" column="subject" type="string"></property>
		<property name="favoriteFood" column="favorite_food" type="string"></property>
		<property name="height" column="height" type="double"></property>
	</class>

</hibernate-mapping>	

映射关系

原始类型

映射类型Java 类型ANSI SQL 类型
integerint 或 java.lang.IntegerINTEGER
longlong 或 java.lang.LongBIGINT
shortshort 或 java.lang.ShortSMALLINT
floatfloat 或 java.lang.FloatFLOAT
doubledouble 或 java.lang.DoubleDOUBLE
big_decimaljava.math.BigDecimalNUMERIC
characterjava.lang.StringCHAR(1)
stringjava.lang.StringVARCHAR
bytebyte 或 java.lang.ByteTINYINT
booleanboolean 或 java.lang.BooleanBIT
yes/noboolean 或 java.lang.BooleanCHAR(1)(‘Y’ or ‘N’)
true/falseboolean 或 java.lang.BooleanCHAR(1) (‘T’ or ‘F’)

日期和时间类型

映射类型Java 类型ANSI SQL 类型
datejava.util.Date 或 java.sql.DateDATE
timejava.util.Date 或 java.sql.TimeTIME
timestampjava.util.Date 或 java.sql.TimestampTIMESTAMP
calendarjava.util.CalendarTIMESTAMP
calendar_datejava.util.CalendarDATE

二进制和大型数据对象

映射类型Java 类型ANSI SQL 类型
binarybyte[]VARBINARY (or BLOB)
textjava.lang.StringCLOB
serializableany Java class that implements java.io.SerializableVARBINARY (or BLOB)
clobjava.sql.ClobCLOB
blobjava.sql.BlobBLOB

JDK 相关类型

映射类型Java 类型ANSI SQL 类型
classjava.lang.ClassVARCHAR
localejava.util.LocaleVARCHAR
timezonejava.util.TimeZoneVARCHAR
currencyjava.util.CurrencyVARCHAR

如果你想了解更多的映射

请去以下网站下载
hibernate4及以上的jar包http://hibernate.org/orm/releases/

hibernate3的相关jar包下载地址
https://sourceforge.net/projects/hibernate/files/hibernate3/

解压缩后可以去找里面的映射文件,名为
Mapping.hbm.xml,不同版本会有不一样的,这里我以单个为例,其实很多时候我们写的那些xml配置文件顶部的内容都是从这里拿的

<?xml version="1.0"?>
<!--
  ~ Hibernate, Relational Persistence for Idiomatic Java
  ~
  ~ License: GNU Lesser General Public License (LGPL), version 2.1 or later.
  ~ See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
  -->
<!DOCTYPE hibernate-mapping PUBLIC
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="org.hibernate.test.collection.custom.parameterized" default-access="field">

    <typedef name="DefaultableList" class="org.hibernate.test.collection.custom.parameterized.DefaultableListType">
        <param name="default">Hello</param>
    </typedef>

    <class name="Entity">
        <id name="name" type="string"/>
        <list name="values" fetch="join" table="ENT_VAL" collection-type="DefaultableList">
            <key column="ENT_ID"/>
            <list-index column="POS"/>
            <element type="string" column="VAL"/>
        </list>
    </class>

</hibernate-mapping>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值