hibernate之映射文件VS映射注解

简介:

前言

  对于java开发者而言,注解应该不是一个陌生的概念,早在JavaSE阶段,例如@Override标记重写父类方法或实现接口方法,@Test标记单元测试方法,所以我们可以简单地把它理解为一种有特殊含义的标记...在开发过程中,我们还可以用注解方式替代配置文件实现相关功能,例如Java web开发中,3.0版本后,利用@WebServlet、@WebListener等注解分别可以替代web项目XML配置文件中相关内容。而本文中讲述的就是Hibernate的映射配置文件与映射注解的对比,这两种方式均可以实现映射功能,为了避免先入为主,在此先不阐述孰优孰劣,接下来以实体类基本映射示例,分别用配置文件和注解方式实现。

hibernate.cfg.xml配置文件在使用两种方式时的变动

<?xml version="1.0"?>
<!DOCTYPE hibernate-configuration PUBLIC    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
    "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <!-- 以下四行分别为:数据库驱动类、Drivermanager获取连接的参数URL、用户名、密码  -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://127.0.0.1/web?characterEcoding=utf-8</property>
        <property name="connection.username">root</property>
        <property name="connection.password">123456</property>
        <!-- 设置方言,hibernate会根据数据库的类型相应生成SQL语句 -->
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>        <!-- 1.使用映射文件时 -->
        <!-- 映射配置源文件的位置 -->
        <mapping resource="demo/pojo/Person.hbm.xml"/>
        <!-- 2.使用映射注解时 -->
        <!-- 注册关系映射类 -->
        <mapping class="demo.pojo.Person" />
    </session-factory>
</hibernate-configuration>

实体类映射

背景:数据库中一个用户表person,字段四个,包涵自增主键id、姓名name、性别sex、年龄age,映射实体类为Person,属性四个,id、name、gender、age。注意这里实体类属性名和数据表中字段名如果不一致,例如这里的sex和gender,在映射文件中<property>标签中name和colum两个属性都要写上,在注解中也不能简化省略@column,column从译意上大家应该都能知道它是对应数据库的字段上,如果不指定字段,默认情况下,系统会把映射文件中的name属性值作为字段名,注解方式时会把属性名作为字段名。另外一个要注意的地方就是类属性是区分大小写的,而字段是不区分大小写的。

映射配置文件

<?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>
    <!-- name是实体类全名,table为数据表名 -->
    <class name="demo.pojo.Person" table="Person">
        <id name="id" column="id">
            <!-- 主键生成方式,native是让hibernate自动识别 -->
            <generator class="native"></generator>
        </id>
        <!-- 
        注意点:
        0.name值为实体类中属性名,column为数据表中字段名;
        1.当实体类中属性名与对应数据表字段名相同时,后面的column可以省略,hibernate会自动匹配,例如下面age ;
        2.反之当实体类中属性名与对应数据表字段名不相同时,两项都要写上,例如下面gender和sex        -->
        <property name="name" column="name"></property>
        <property name="gender" column="sex"></property>
        <property name="age"></property>
    </class></hibernate-mapping>

映射注解方式

package demo.pojo;import javax.persistence.Column;import javax.persistence.Entity;import javax.persistence.GeneratedValue;import javax.persistence.GenerationType;import javax.persistence.Id;import javax.persistence.Table;//实体类属性注解,这里统一写在各属性的get方法上@Entity//标记实体类@Table(name="person",catalog="web")//name对应数据表名,catalog对应数据库名public class Person {    
    private Integer id;    private String name;    private String gender;    private Integer age;
    @Id//标记主键
    @Column(name="id")//主键字段名,这里与类属性id是对应相同的,此行可以简化不写
    @GeneratedValue(strategy=GenerationType.AUTO)//主键生成策略,自动识别
    public Integer getId() {        return id;
    }    public void setId(Integer id) {        this.id = id;
    }
    @Column(name="name")//主键字段名,这里与类属性name是对应相同的,此行可以简化不写
    public String getName() {        return name;
    }    public void setName(String name) {        this.name = name;
    }
    @Column(name="sex")//主键字段名,这里与类属性gender是对应,但不相同,不可省略
    public String getGender() {        return gender;
    }    public void setGender(String gender) {        this.gender = gender;
    }    //省略注解
    public Integer getAge() {        return age;
    }    public void setAge(Integer age) {        this.age = age;
    }
    @Override    public String toString() {        return "Person [id=" + id + ", name=" + name + ", gender=" + gender + ", age=" + age + "]";
    }
    
    
}

 

注意点

  0.在hibernate.cfg.xml配置文件中,使用两种映射方式分别要填映射配置源文件的位置和映射类的全名,一个是<mapping resource="XX/XX/XXX">,一个是<mapping class="XXX.XXX.XXX" />;

  1.在使用注解方式时,实体类中导入不要导成Hibernate下的,这里引入都是JPA(Java Persistence API)范畴下的类,不要因为是hibernate框架下,顺其自然地以为是那个Hibernate下的类,图示如下

本文转自  zddnd   51CTO博客,原文链接:http://blog.51cto.com/13013666/1949226

相关文章
|
6月前
|
Java 数据库连接
hibernate注解实体类(Dept.java)
hibernate注解实体类(Dept.java)
|
6月前
|
XML Java 数据库连接
struts+hibernate+oracle+easyui实现lazyout组件的简单案例——hibernate的config文件(hibernate.cfg.xml)
struts+hibernate+oracle+easyui实现lazyout组件的简单案例——hibernate的config文件(hibernate.cfg.xml)
|
6月前
|
Java 数据库连接
Hibernate中使用Criteria查询及注解——(Dept.java)
Hibernate中使用Criteria查询及注解——(Dept.java)
|
2月前
|
Java 数据库连接 API
解锁高效开发秘籍:深入探究 Hibernate 如何优雅处理一对多与多对多关系,让数据映射再无烦恼!
【9月更文挑战第3天】Hibernate 是 Java 领域中最流行的 ORM 框架之一,广泛用于处理实体对象与数据库表之间的映射。尤其在处理复杂关系如一对多和多对多时,Hibernate 提供了丰富的 API 和配置选项。本文通过具体代码示例,展示如何使用 `@OneToMany`、`@JoinColumn`、`@ManyToMany` 和 `@JoinTable` 等注解优雅地实现这些关系,帮助开发者保持代码简洁的同时确保数据一致性。
45 4
|
3月前
|
XML JSON Java
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
本文介绍了如何使用IntelliJ IDEA和Maven搭建一个整合了Struts2、Spring4、Hibernate4的J2EE项目,并配置了项目目录结构、web.xml、welcome.jsp以及多个JSP页面,用于刷新和学习传统的SSH框架。
83 0
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
|
3月前
|
Java 数据库连接 数据库
AI 时代风起云涌,Hibernate 实体映射引领数据库高效之路,最佳实践与陷阱全解析!
【8月更文挑战第31天】Hibernate 是一款强大的 Java 持久化框架,可将 Java 对象映射到关系数据库表中。本文通过代码示例详细介绍了 Hibernate 实体映射的最佳实践,包括合理使用关联映射(如 `@OneToMany` 和 `@ManyToOne`)以及正确处理继承关系(如单表继承)。此外,还探讨了常见陷阱,例如循环依赖可能导致的无限递归问题,并提供了使用 `@JsonIgnore` 等注解来避免此类问题的方法。通过遵循这些最佳实践,可以显著提升开发效率和数据库操作性能。
83 0
|
3月前
|
数据库 开发者 Java
Hibernate映射注解的魔力:实体类配置的革命,让你的代码量瞬间蒸发!
【8月更文挑战第31天】Hibernate 是一款出色的对象关系映射框架,简化了 Java 应用与数据库的交互。其映射注解让实体类配置变得直观简洁。本文深入剖析核心概念与使用技巧,通过示例展示如何简化配置。
41 0
|
5月前
|
JSON Java 数据库连接
Hibernate中使用@Lob 注解保存String[] 问题
Hibernate中使用@Lob 注解保存String[] 问题
31 2
|
6月前
|
Java 数据库连接
Hibernate中使用Criteria查询及注解——(Emp.hbm.xml)
Hibernate中使用Criteria查询及注解——(Emp.hbm.xml)
|
6月前
|
Java 数据库连接
hibernate注解实体类(Emp.java)
hibernate注解实体类(Emp.java)