zoukankan      html  css  js  c++  java
  • 笔记47 Hibernate快速入门(四)

    Hibernate注解,完成原来xml文件里的映射信息。

    使用注解时,要修改hibernate.cfg.xml中的映射,不再是通过xml文件

    1 <mapping class="hibernate.pojo.annotation.Product" />
    2 <mapping class="hibernate.pojo.annotation.Category" />
    3 <mapping class="hibernate.pojo.annotation.User" />

    一、类与属性

     1 package hibernate.pojo.annotation;
     2 
     3 import java.util.Set;
     4 
     5 import javax.persistence.CascadeType;
     6 import javax.persistence.Column;
     7 import javax.persistence.Entity;
     8 import javax.persistence.FetchType;
     9 import javax.persistence.GeneratedValue;
    10 import javax.persistence.GenerationType;
    11 import javax.persistence.Id;
    12 import javax.persistence.JoinColumn;
    13 import javax.persistence.JoinTable;
    14 import javax.persistence.ManyToMany;
    15 import javax.persistence.ManyToOne;
    16 import javax.persistence.Table;
    17 
    18 @Entity
    19 @Table(name = "product")
    20 public class Product {
    21     int id;
    22     String name;
    23     float price;
    24     Category category;
    25     Set<User> users;
    26     int version;
    27 
    28     @Id
    29     @GeneratedValue(strategy = GenerationType.IDENTITY)
    30     public int getId() {
    31         return id;
    32     }
    33 
    34     public void setId(int id) {
    35         this.id = id;
    36     }
    37 
    38     @Column(name = "name")
    39     public String getName() {
    40         return name;
    41     }
    42 
    43     public void setName(String name) {
    44         this.name = name;
    45     }
    46 
    47     @Column(name = "price")
    48     public float getPrice() {
    49         return price;
    50     }
    51 
    52     public void setPrice(float price) {
    53         this.price = price;
    54     }
    55 
    56     @ManyToOne
    57     @JoinColumn(name = "cid")
    58     public Category getCategory() {
    59         return category;
    60     }
    61 
    62     public void setCategory(Category category) {
    63         this.category = category;
    64     }
    65 
    66     @ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
    67     @JoinTable(name = "user_product", joinColumns = @JoinColumn(name = "pid"), inverseJoinColumns = @JoinColumn(name = "uid"))
    68     public Set<User> getUsers() {
    69         return users;
    70     }
    71 
    72     public void setUsers(Set<User> users) {
    73         this.users = users;
    74     }
    75 
    76     public int getVersion() {
    77         return version;
    78     }
    79 
    80     public void setVersion(int version) {
    81         this.version = version;
    82     }
    83 
    84 }

    1.类注解

    在上面的代码中,Product类声明前面有两个注解:@Entity 和 @Table(name = "product")

    @Entity 表示这是一个实体类,用于映射表
    @Table(name = "product") 表示这是一个类,映射到的表名:product

    2.属性注解

    属性注解是配置在属性对应的getter方法上的

    1     @Id
    2     @GeneratedValue(strategy = GenerationType.IDENTITY) 
    3     @Column(name = "id")   
    4     public int getId() {
    5         return id;
    6     }

    @Id 表示这是主键
    @GeneratedValue(strategy = GenerationType.IDENTITY) 表示自增长方式使用mysql自带的
    @Column(name = "id") 表示映射到字段id

    二、关系

    1.多对一注解

    在product表中多个产品可以对应一种类别。

    把Product的getCategory进行多对一映射:

    1     @ManyToOne
    2     @JoinColumn(name="cid") 
    3     public Category getCategory() {
    4         return category;
    5     }

    @ManyToOne 表示多对一关系
    @JoinColumn(name="cid") 表示关系字段是cid

    2.一对多注解

    在category表中,一种类别可以对应多种产品。

    在Category类中的getProducts方法加上一对多注解:

    1     @OneToMany(fetch=FetchType.EAGER)
    2     @JoinColumn(name="cid") 
    3     public Set<Product> getProducts() {
    4         return products;
    5     }

    @OneToMany 表示一对多,fetch=FetchType.EAGER 表示不进行延迟加载(FetchType.LAZY表示要进行延迟加载)
    @JoinColumn(name="cid") 表示映射字段

    *cid字段存在多的一方

    3.多对多注解

    多对多涉及到user和product表,一个用户可以购买多个产品,一个产品可以被多个用户购买。

    <1>为Product的getUsers加上注解

    1     @ManyToMany(cascade=CascadeType.ALL,fetch=FetchType.EAGER)
    2     @JoinTable(
    3             name="user_product",
    4             joinColumns=@JoinColumn(name="pid"),
    5             inverseJoinColumns=@JoinColumn(name="uid")
    6     )    
    7     public Set<User> getUsers() {
    8         return users;
    9     }

    <2>为User的getProducts加上注解

    1     @ManyToMany(cascade=CascadeType.ALL,fetch=FetchType.EAGER)
    2     @JoinTable(
    3             name="user_product",
    4             joinColumns=@JoinColumn(name="uid"),
    5             inverseJoinColumns=@JoinColumn(name="pid")
    6     )    
    7     public Set<Product> getProducts() {
    8         return products;
    9     }

    三、注解手册

    1.属性相关注解

    @Id —— 注解声明了该实体bean的标识属性(对应表中的主键)。 

    @Column —— 注解声明了属性到列的映射。该注解有如下的属性 

    name 可选,列名(默认值是属性名) 

    unique 可选,是否在该列上设置唯一约束(默认值false) 

    nullable 可选,是否设置该列的值可以为空(默认值false) 

    insertable 可选,该列是否作为生成的insert语句中的一个列(默认值true) 

    updatable 可选,该列是否作为生成的update语句中的一个列(默认值true) 

    columnDefinition 可选,为这个特定列覆盖sql ddl片段(这可能导致无法在不同数据库间移植) 

    table 可选,定义对应的表(默认为主表) 

    length 可选,列长度(默认值255) 

    precision 可选,列十进制精度(decimal precision)(默认值0) 

    scale 可选,如果列十进制数值范围(decimal scale)可用,在此设置(默认值0) 

    @GeneratedValue —— 注解声明了主键的生成策略。该注解有如下属性 

    strategy 指定生成的策略(JPA定义的),这是一个GenerationType。默认是GenerationType. AUTO 

    GenerationType.AUTO 主键由程序控制 

    GenerationType.TABLE 使用一个特定的数据库表格来保存主键 

    GenerationType.IDENTITY 主键由数据库自动生成(主要是自动增长类型) 

    GenerationType.SEQUENCE 根据底层数据库的序列来生成主键,条件是数据库支持序列。(这个值要与generator一起使用) 

    generator 指定生成主键使用的生成器(可能是orcale中的序列)。 

    @SequenceGenerator —— 注解声明了一个数据库序列。该注解有如下属性 

    name 表示该表主键生成策略名称,它被引用在@GeneratedValue中设置的“gernerator”值中 

    sequenceName 表示生成策略用到的数据库序列名称。 

    initialValue 表示主键初始值,默认为0. 

    allocationSize 每次主键值增加的大小,例如设置成1,则表示每次创建新记录后自动加1,默认为50.

    2.关系相关注解

    @ManyToOne 设置多对一关联 

    方法一 

    @ManyToOne(cascade={CasCadeType.PERSIST,CascadeType.MERGE})

    @JoinColumn(name="外键") 

    public 主表类 get主表类(){return 主表对象} 

    方法二 

    @ManyToOne(cascade={CascadeType.PERSIST,CascadeType.MERGE}) 

    @JoinTable(name="关联表名", 

    joinColumns = @JoinColumn(name="主表外键"), 

    inverseJoinColumns = @JoinColumns(name="从表外键") 

    @OneToMany 设置一对多关联。

    方法一 

    “一端”配置 

    @OneToMany(mappedBy="“多端”的属性") 

    public List<“多端”类> get“多端”列表(){return “多端”列表} 

    “多端”配置参考@ManyToOne. 

    方法二 

    “一端”配置 

    @OneToMany(mappedBy="“多端”的属性") 

    @MapKey(name="“多端”做为Key的属性") 

    public Map<“多端”做为Key的属性的类,主表类> get“多端”列表(){return “多端”列表} 

    “多端”配置参考@ManyToOne. 

    方法三 使用这种配置,在为“一端”添加“多端”时,可以修改“多端”的外键。 

    “一端”配置 

    @OneToMany 

    @JoinColumn(name="“多端”外键") 

    public List<“多端”类> get“多端”列表(){return “多端”列表} 

    “多端”配置参考@ManyToOne.

  • 相关阅读:
    【Leetcode】【hard】Binary Tree Postorder Traversal
    【Leetcode】【Easy】Contains Duplicate
    【Leetcode】【Easy】Isomorphic Strings
    【Leetcode】【Medium】Simplify Path
    【Leetcode】【Medium】Add Two Numbers
    【Leetcode】【Hard】Copy List with Random Pointer
    安装torch-opencv
    【转】ubuntu下修改文件夹权限
    Lua 中的 function、closure、upvalue
    多目标跟踪方法 NOMT 学习与总结
  • 原文地址:https://www.cnblogs.com/lyj-gyq/p/9195580.html
Copyright © 2011-2022 走看看