JPA 實體映射

来源:https://www.cnblogs.com/gdwkong/archive/2018/03/20/8608672.html
-Advertisement-
Play Games

一、實體基本映射 二、實體表間映射 1、一對一實體映射:人與地址 2、一對多實體映射:員工表與部門表 3、多對多實體映射:老師與學生 ...


一、實體基本映射

 1 /*
 2 * @Entity:將領域對象標註為一個實體,表示保存到資料庫中
 3 * @@Table:保存到資料庫中表名,預設表名為類名,可通過name屬性命名
 4 *
 5 * */
 6 @Entity
 7 @Table(name="t_user")
 8 public class User {
 9 
10 
11     @Id //主鍵
12     @GeneratedValue // JPA自動選擇合適的生成策略
13     @Column(name="id_") //列名,預設為屬性名,可通過name屬性指定列名
14     private Integer id;    
15     
16     
17 /*    @Id
18     @GeneratedValue(generator="uuidGenerator")
19     @GenericGenerator(name="uuidGenerator",strategy="uuid") //UUID生成策略
20     @Column(name="id_",length=32)
21     private String id;*/
22     
23     
24 /*    @Id
25     @GeneratedValue(strategy = GenerationType.AUTO) //JPA自動選擇合適的策略,是預設選項
26     @Column(name="id_")
27     private Integer id;*/
28     
29         
30     /*
31      *     
32     @Id
33     @GeneratedValue(strategy=GenerationType.IDENTITY) //表示自增鍵欄位,oracle不支持這種方式
34     @Column(name="id_")
35     private Integer id;*/
36     
37     
38     /*    
39     @Id
40     @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "idGenerator") //通過序列產生主鍵,通過@SequenceGenerator註解指定序列列名,mysql不支持這種方式
41     @SequenceGenerator(name = "idGenerator",sequenceName="mySeq",allocationSize=1)
42     @Column(name="id_")
43     private Integer id;*/    
44     
45     /*    
46     @Id
47     @GeneratedValue(strategy = GenerationType.TABLE, generator = "userGenerator")//通過表產生主鍵,框架藉由表模擬序列產生主鍵,使用該策略可以使應用更易於資料庫移植。
48     @TableGenerator(name = "userGenerator",table="pk_generator",
49                     pkColumnName="gen_name",
50                     valueColumnName="gen_value",
51                     pkColumnValue="user_pk",
52                     initialValue=0,
53                     allocationSize=1)
54     @Column(name="id_")
55     private Integer id;    
56     */
57 
58     //length:欄位的長度;nullable:是否允許為空;unique:指定是否唯一性;insertable updatable:指定該欄位是否插入或修改到資料庫表中,對應表中需通過columnDefinition指定預設值;
59     @Column(name="name_", length=60, nullable=false,unique=true,insertable=false,updatable=false)
60     private String name;
61     
62     @Column(name="address_", length=60, nullable=false)
63     private String address;
64     
65     @Column(name="phone_", length=11, nullable=true,columnDefinition="CHAR(10) default '000'") //columnDefinition:底層資料庫的欄位類型,根據不同資料庫配置
66     private String phone;
67     
68     @Column(name="inCome_", precision=12, scale=2) //precision:浮點型總長度;scale:小數的位數
69     private BigDecimal inCome;
70     
71     @Temporal(TemporalType.DATE) //如果屬性是時間類型,因為數據表對時間類型有更嚴格的劃分,所以必須指定具體時間類型。
72     private Date birthday;
73     //Date 日期型,精確到年月日,例如“2008-08-08”
74     //Time 時間型,精確到時分秒,例如“20:00:00”
75     //Timestamp 時間戳,精確到納秒,例如“2008-08-08 20:00:00.000000001”
76     
77     @Lob
78     @Column(name="pic_")
79     @Basic(fetch=FetchType.LAZY)
80     private byte[] pic;
81     
82     @Lob
83     @Column(name="note_")
84     @Basic(fetch=FetchType.LAZY)
85     private String note;
86     
87     ...........
88 }    

二、實體表間映射

1、一對一實體映射:人與地址

 1 @Entity
 2 public class Person {
 3     @Id 
 4     @GeneratedValue(strategy = GenerationType.AUTO) 
 5     private Long id; 
 6     private String name;
 7     private int age;
 8     //@OneToOne 一對一映射,級聯操作,通過cascade屬性設置;懶載入操作,通過fetch屬性設置
 9     @OneToOne(cascade={CascadeType.REFRESH,CascadeType.REMOVE},fetch=FetchType.LAZY)
10     //@JoinColumn:Person中address欄位對應的"address_id"表示Address中"aid"欄位,即外鍵關係;如自動建表,@JoinColum註解可省略
11     @JoinColumn(name="address_id",referencedColumnName="aid")
12     //@JoinColumns(value={@JoinColumn(name="address_id",referencedColumnName="aid"),@JoinColumn(name="address_id2",referencedColumnName="aid2")})
13     private Address address;
14 ...........
15 }
 1 @Entity
 2 public class Address {
 3 
 4     @Id
 5     @GeneratedValue(strategy = GenerationType.AUTO)
 6     private Long aid;
 7     private String street;
 8     private String city;
 9     private String country;
10     
11 
12     @Column(name="aid_")
13     public Long getAid() {
14         return aid;
15     }
16 .............
17 }

2、一對多實體映射:員工表與部門表

 1 @Entity
 2 public class Depart {
 3     @Id
 4     @GeneratedValue
 5     private Long did;
 6     private String name;
 7 
 8     @OneToMany //一對多映射
 9     /*
10         通過中間表關聯
11       @JoinTable 配置中間表信息,name:中間表名;
12        joinColumns:部門表與中間表間的關係,"depart_id"部門表中的主鍵欄位作為中間表中外鍵(did)欄位
13        inverseJoinColumns:被擁有者,即員工表與中間表的關係
14     */
15     @JoinTable(name = "depart_employee", 
16         joinColumns = @JoinColumn(name = "depart_id",referencedColumnName="did"), 
17         inverseJoinColumns = @JoinColumn(name = "employee_id",referencedColumnName="eid"))
18     /*
19         通過設置外鍵關聯
20         設置"did"欄位做為另一方的外鍵"depart_id"
21     @JoinColumn(name="depart_id",referencedColumnName="did")
22     */
23     private List<Employee> employees;
24 .....
25 }
1 @Entity
2 public class Employee {
3     @Id 
4     @GeneratedValue(strategy = GenerationType.AUTO) 
5     private Long eid; 
6     private String  name;
7 .......
8 }

3、多對多實體映射:老師與學生

 1 @Entity
 2 public class Teacher {
 3 
 4     @Id 
 5     @GeneratedValue(strategy = GenerationType.AUTO) 
 6     private Long tid; 
 7     private String name; 
 8     private Boolean gender; 
 9     private int age; 
10     private int height; 
11     @ManyToMany 
12     @JoinTable(name = "teacher_student", 
13         joinColumns = @JoinColumn(name = "teacher_id",referencedColumnName="tid"), 
14         inverseJoinColumns = @JoinColumn(name = "student_id",referencedColumnName="sid"))
15     private List<Student> students;
16 ..........
17 }
 1 @Entity
 2 public class Student {
 3 
 4     @Id 
 5     @GeneratedValue(strategy = GenerationType.AUTO) 
 6     private Long sid; 
 7     private String name; 
 8     private Boolean gender; 
 9     private int age; 
10     private int height;
11     
12     @ManyToMany(mappedBy = "students") 
13     private List<Teacher> teachers; 
14 ...............
15 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 三、xadmin後臺管理 3.1.xadmin的安裝 django2.0的安裝(源碼安裝方式): 把zip文件放到pip目錄下,運行下麵命令安裝: 是文件README.rst 出現了 Unicode 解碼錯誤,這個文件是沒有什麼用處的,可以新建一個同名的空白文件替換掉 首先下載zip源碼包:gith ...
  • 想用Python做爬蟲,而你卻還不會Python的話,那麼這些入門基礎知識必不可少。很多小伙伴,特別是在學校的學生,接觸到爬蟲之後就感覺這個好厲害的樣子,我要學。但是卻完全不知道從何開始,很迷茫,學的也很雜,下麵就跟著小編一起來看看想用python來做爬蟲到底需要學習哪些知識吧! Python入門 ...
  • 軟體質量與測試 第二周作業 WordCount Github地址: https://github.com/Hu-Peking/WordCount PSP2.1: 解題思路: 1、將程式的功能需求分為基礎功能和拓展功能,按先後順序分別實現兩部分的內容; 2、先在IDE中實現對電腦中指定目錄下的文件的讀 ...
  • MySQL事務隔離級別 1. 臟讀: 騙錢的手段, 兩個視窗或線程分別調用資料庫轉賬表,轉賬後未提交,對方查看到賬後,rollback,實際錢沒轉. 演示方法: mysql預設的事務隔離級別為repeatable-read 比Oracle高,因為mysql本身弱 使用select @@tx_isol ...
  • 今天發現一個超級坑的異常, 如上, 問題所在:頁面中的el表達式中拿不到User對象中的'name'值 頁面裡面的${USER.name}改為${USER.username}就解決了 ...
  • 為什麼這樣說呢,我幾個月前就開始學python,但是一直都沒有進步,還就只是會一些其它語言的共性的問題,也就是新學習的約等於0. 後來一直找一些適合自己的教材,通過同學找到了一個學長的教程。 開始了新的python旅程 最近打字有點懶了五筆都有點生疏了 還是看手抄版的筆記吧 給自己學習的動力從新的一 ...
  • 註:這裡只描述使用方法,具體類的概念長篇大論就不要為難我這個懶人了。 總之一句話編程語言只是一個工具,會用就行,好用就行。打破砂鍋問到底,我覺得有必要研究一下C,彙編,電子鏈路等。 ...
  • 一、SpringData入門 在上次學SpringBoot的時候,那時候的教程就已經涉及到了一點SpringData JPA的知識了。當時還是第一次見,覺得也沒什麼大不了,就是封裝了Hibernate的API而已。 然後在慕課網上又看到了SpringData的教程了。於是就進去學習了一番。 教程地址 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...