Hibernate注解开发

本文介绍了Hibernate注解开发,包括PO类注解配置、一对多、多对多和一对一的关联映射。详细讲解了@Entity、@Table、@Id、@GeneratedValue等注解的使用,以及在不同关联映射中的配置策略,如 cascade 和 mappedBy 的应用。通过示例代码展示了如何在Hibernate中使用注解实现数据持久化和关联操作。
摘要由CSDN通过智能技术生成

Hibernate注解开发

在Hibernate中我们一般都会使用注解,这样可以帮助我们大大简化hbm映射文件的配置。下面我就来为大家详细介绍。

PO类注解配置

首先肯定是搭建好Hibernate的开发环境啦,我在此也不过多赘述,读者自行实践。接着在src目录下创建一个cn.itheima.domain包,并在该包下创建一个Book实体类,由于Book实体类中写有注解配置,所以就不用编写那个映射配置文件啦!

@Entity // 定义了一个实体
@Table(name="t_book",catalog="hibernateTest")
public class Book {
   

    @Id // 这表示一个主键
    // @GeneratedValue 相当于native主键生成策略
    @GeneratedValue(strategy=GenerationType.IDENTITY) // 相当于identity主键生成策略
    private Integer id; // 主键

    @Column(name="c_name", length=30, nullable=true)
    private String name;

    @Temporal(TemporalType.TIMESTAMP) // 是用来定义日期类型
    private Date publicationDate; // 出版日期

    @Type(type="double") // 允许你去指定Hibernate里面的一些类型
    private Double price; // 价格,如果没有添加注解,也会自动的生成在表中

    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 Date getPublicationDate() {
        return publicationDate;
    }
    public void setPublicationDate(Date publicationDate) {
        this.publicationDate = publicationDate;
    }
    public Double getPrice() {
        return price;
    }
    public void setPrice(Double price) {
        this.price = price;
    }

}

下面我就来详细说一下Book实体类中的注解。

  • @Entity:声明一个实体。
  • @Table:来描述类与表之间的对应关系。

    @Entity // 定义了一个实体
    @Table(name="t_book",catalog="hibernateTest")
    public class Book {
         
        ......
    }
  • @id:声明一个主键。
  • @GeneratedValue:用它来声明一个主键生成策略。默认情况是native主键生成策略。可以选择的主键生成策略有:AUTO、IDENTITY、SEQUENCE。

    @Id // 这表示一个主键
    // @GeneratedValue 相当于native主键生成策略
    @GeneratedValue(strategy=GenerationType.IDENTITY) // 相当于identity主键生成策略
    private Integer id; // 主键
  • @Column:定义列。

    @Column(name="c_name", length=30, nullable=true)
    private String name;

    注意:对于PO类中所有属性,如果你不写注解,默认情况下也会在表中生成对应的列,列的名称就是属性的名称,列的类型也即属性的类型

  • @Temporal:声明日期类型。

    @Temporal(TemporalType.TIMESTAMP) // 是用来定义日期类型
    private Date publicationDate; // 出版日期

    日期类型可以选择的有:

    • TemporalType.DATA:只有年月日。
    • TemporalType.TIME:只有小时分钟秒。
    • TemporalType.TIMESTAMP:有年月日小时分钟秒。
  • @Type:可允许你去指定Hibernate里面的一些类型。

    @Type(type="double") // 允许你去指定Hibernate里面的一些类型
    private Double price; // 价格,如果没有添加注解,也会自动的生成在表中

编写完上述Book实体类之后,千万不要忘记下面这一步:我们最终需要在hibernate.cfg.xml文件中将我们类中的注解配置引用生效。即需要在Hibernate核心配置文件中添加如下配置:

<mapping class="cn.itheima.domain.Book"/>

最后我们在src目录下创建一个cn.itheima.test包,在该包下编写一个HibernateAnnotationTest单元测试类,并在该类中编写一个用于测试PO类的注解开发的方法:

public class HibernateAnnotationTest {

    // 测试PO的注解开发
    @Test
    public void test1() {
        Session session = HibernateUtils.openSession();
        session.beginTransaction();

        Book b = new Book();
        b.setName("情书");
        b.setPrice(56.78);
        b.setPublicationDate(new Date());

        session.save(b);

        session.getTransaction().commit();
        session.close();
    }

}

现在来思考两个问题:

  1. 如果主键生成策略我们想使用UUID类型呢?
  2. 如何设定类的属性不在表中映射?

这两个问题我们一起解决。废话不多说,直接上例子。在cn.itheima.domain包下再编写一个Person实体类,同样使用注解配置。

@Entity
@Table(name="t_person", catalog="hibernateTest")
public class Person {
   

    // 生成UUID的主键生成策略
    @Id
    @GenericGenerator(name="myuuid", strategy="uuid") // 声明一种主键生成策略(uuid)
    @GeneratedValue(generator="myuuid") // 引用uuid主键生成策略
    private String id;

    @Type(type="string") // 允许你去指定Hibernate里面的一些类型
    private String name;

    @Transient</
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李阿昀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值