欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaBean實(shí)體類處理外鍵過程解析

 更新時(shí)間:2020年07月30日 08:30:48   作者:-超級(jí)菜鳥-  
這篇文章主要介紹了JavaBean實(shí)體類處理外鍵過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

數(shù)據(jù)庫(kù)中的表在映射為JavaBean的實(shí)體類時(shí),實(shí)體類的字段名應(yīng)與數(shù)據(jù)庫(kù)表中的字段名一致。那么外鍵要怎么處理?

1. JavaBean中實(shí)體類中不應(yīng)該出現(xiàn)外鍵字段,弊端如下 :

如果出現(xiàn)外鍵對(duì)應(yīng)的字段,那么將會(huì)出現(xiàn)一個(gè)對(duì)象與另一個(gè)對(duì)象的屬性相對(duì)應(yīng),這將不是面向?qū)ο笾械膶?duì)象與對(duì)象對(duì)應(yīng)。

單個(gè)外鍵只能存儲(chǔ)一個(gè)字符串,用處不大

2.外鍵處理方式 :數(shù)據(jù)庫(kù)表中的外鍵字段應(yīng)當(dāng)轉(zhuǎn)換成外鍵對(duì)應(yīng)的表的對(duì)象,也就是JavaBean的實(shí)體類不聲明外鍵的字段,而是聲明外鍵對(duì)應(yīng)數(shù)據(jù)表類的類型。舉個(gè)例子,如下 :

數(shù)據(jù)庫(kù)建表如下 :

-- 1.1 創(chuàng)建用戶表
CREATE TABLE `user` (
 `uid` varchar(32) NOT NULL, #用戶編號(hào)
 `username` varchar(20) DEFAULT NULL,   #用戶名
 `password` varchar(20) DEFAULT NULL,   #密碼
 `name` varchar(20) DEFAULT NULL,     #昵稱
 `email` varchar(30) DEFAULT NULL,     #電子郵箱
 `telephone` varchar(20) DEFAULT NULL,   #電話
 `birthday` date DEFAULT NULL,       #生日
 `sex` varchar(10) DEFAULT NULL,      #性別
 `state` int(11) DEFAULT 0,        #狀態(tài):0=未激活,1=已激活
 `code` varchar(64) DEFAULT NULL,     #激活碼
 PRIMARY KEY (`uid`)
) ENGINE=InnoDB ;
 
-- 2.1 創(chuàng)建分類表
CREATE TABLE `category` (
 `cid` varchar(32) NOT NULL,
 `cname` varchar(20) DEFAULT NULL, #分類名稱
 PRIMARY KEY (`cid`)
) ENGINE=InnoDB ;
 
-- 3.1 創(chuàng)建商品表
CREATE TABLE `product` (
 `pid` varchar(32) NOT NULL,
 `pname` varchar(50) DEFAULT NULL,   #商品名稱
 `market_price` double DEFAULT NULL,  #市場(chǎng)價(jià)
 `shop_price` double DEFAULT NULL,   #商城價(jià)
 `pimage` varchar(200) DEFAULT NULL,  #商品圖片路徑
 `pdate` date DEFAULT NULL,      #上架時(shí)間
 `is_hot` int(11) DEFAULT NULL,    #是否熱門:0=不熱門,1=熱門
 `pdesc` varchar(255) DEFAULT NULL,  #商品描述
 `pflag` int(11) DEFAULT 0,      #商品標(biāo)記:0=未下架(默認(rèn)值),1=已經(jīng)下架
 `cid` varchar(32) DEFAULT NULL,    #分類id
 PRIMARY KEY (`pid`),
 KEY `product_fk_0001` (`cid`),
 CONSTRAINT `product_fk_0001` FOREIGN KEY (`cid`) REFERENCES `category` (`cid`)
) ENGINE=InnoDB ;
 
-- 4 創(chuàng)建訂單表
CREATE TABLE `order` (
 `oid` varchar(32) NOT NULL,
 `ordertime` datetime DEFAULT NULL,    #下單時(shí)間
 `total` double DEFAULT NULL,       #總價(jià)
 `state` int(11) DEFAULT NULL,       #訂單狀態(tài):1=未付款;2=已付款,未發(fā)貨;3=已發(fā)貨,沒收貨;4=收貨,訂單結(jié)束
 `address` varchar(30) DEFAULT NULL,    #收獲地址
 `name` varchar(20) DEFAULT NULL,     #收獲人
 `telephone` varchar(20) DEFAULT NULL,   #收貨人電話
 `uid` varchar(32) DEFAULT NULL,
 PRIMARY KEY (`oid`),
 KEY `order_fk_0001` (`uid`),
 CONSTRAINT `order_fk_0001` FOREIGN KEY (`uid`) REFERENCES `user` (`uid`)
) ENGINE=InnoDB ;
 
-- 5 創(chuàng)建訂單項(xiàng)表
CREATE TABLE `orderitem` (
 `itemid` varchar(32) NOT NULL,
 `quantity` int(11) DEFAULT NULL,     #購(gòu)買數(shù)量
 `total` double DEFAULT NULL,     #小計(jì)
 `pid` varchar(32) DEFAULT NULL,    #購(gòu)買商品的id
 `oid` varchar(32) DEFAULT NULL,    #訂單項(xiàng)所在訂單id
 PRIMARY KEY (`itemid`),
 KEY `order_item_fk_0001` (`pid`),
 KEY `order_item_fk_0002` (`oid`),
 CONSTRAINT `order_item_fk_0001` FOREIGN KEY (`pid`) REFERENCES `product` (`pid`),
 CONSTRAINT `order_item_fk_0002` FOREIGN KEY (`oid`) REFERENCES `order` (`oid`)
) ENGINE=InnoDB ;

其中訂單與訂單項(xiàng)的JavaBean的實(shí)體類如下 :

/**
 * 訂單項(xiàng)
 */
public class OrderItem {
 
  private String itemid ;   // 訂單項(xiàng)編號(hào)
  private Integer quantity;    // 購(gòu)買數(shù)量
  private Double total;  // 小計(jì)
 
  private Product product ;  // 商品對(duì)象
  private Order order ;    // 訂單項(xiàng)所在訂單對(duì)象
  ......
}
 
/**
 * 訂單實(shí)體類
 */
public class Order {
   
  private String oid ;    // 訂單編號(hào)
  private Date ordertime; // 下單時(shí)間
  private Double total ;   // 總價(jià)
  private Integer state ;   // 訂單狀態(tài) : 1 : 未付款 2 : 已付款,未發(fā)貨  3 :已發(fā)貨,未收貨  4: 已收貨,訂單結(jié)束
  private String address ;  // 收貨地址
  private String name ;    // 收件人姓名 : 收件人不一定是購(gòu)買人
  private String telephone ; // 收件人電話
 
  private User user ;     // 訂單所屬的用戶
   
  private List<OrderItem> list = new ArrayList<>() ; // 訂單項(xiàng)集合
  ......
}

這樣做的優(yōu)點(diǎn)如下 :

  • 程序?qū)ο蠛蛯?duì)象產(chǎn)生關(guān)系,而不是對(duì)象(Order的對(duì)象)和對(duì)象的屬性(User對(duì)象的uid)產(chǎn)生關(guān)系
  • 設(shè)計(jì)Order的目的 : 讓order攜帶訂單上的數(shù)據(jù)向service層,dao層傳遞,user對(duì)象是可以攜帶更多的數(shù)據(jù)的
  • 程序中體現(xiàn)訂單對(duì)象和訂單項(xiàng)對(duì)象之間的關(guān)系,項(xiàng)目中的部分功能中有類似的需求 : 查詢訂單的同時(shí),還要獲取訂單下所有的訂單項(xiàng)

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • java實(shí)現(xiàn)Excel的導(dǎo)入導(dǎo)出

    java實(shí)現(xiàn)Excel的導(dǎo)入導(dǎo)出

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)Excel的導(dǎo)入導(dǎo)出,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • Java中和隊(duì)列相關(guān)的基本操作

    Java中和隊(duì)列相關(guān)的基本操作

    在Java中,隊(duì)列是一種常用的數(shù)據(jù)結(jié)構(gòu),用于存儲(chǔ)和管理元素。Java提供了Queue接口和其實(shí)現(xiàn)類,包括LinkedList和ArrayDeque等。隊(duì)列的基本操作包括入隊(duì)(enqueue)、出隊(duì)(dequeue)、獲取隊(duì)首元素(peek)和判斷隊(duì)列是否為空(isEmpty)。
    2023-09-09
  • Java HttpClient用法的示例詳解

    Java HttpClient用法的示例詳解

    Java開發(fā)語言中實(shí)現(xiàn)HTTP請(qǐng)求的方法主要有兩種:一種是JAVA的標(biāo)準(zhǔn)類HttpUrlConnection;另一種是第三方開源框架HTTPClient。本文就將詳細(xì)講講Java中HttpClient的使用,需要的可以參考一下
    2022-07-07
  • IDEA之翻譯器的使用Translation

    IDEA之翻譯器的使用Translation

    這篇文章主要介紹了IDEA之翻譯器的使用Translation,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Java String 和StringBuffer的詳解及區(qū)別

    Java String 和StringBuffer的詳解及區(qū)別

    這篇文章主要介紹了Java String 和StringBuffer的詳解及區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 基于Jasypt對(duì)SpringBoot配置文件加密

    基于Jasypt對(duì)SpringBoot配置文件加密

    這篇文章主要介紹了基于Jasypt對(duì)SpringBoot配置文件加密,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • springboot命令行啟動(dòng)的方法詳解

    springboot命令行啟動(dòng)的方法詳解

    這篇文章主要介紹了springboot命令行啟動(dòng)的方法,本文通過兩種方法給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • java實(shí)現(xiàn)猜數(shù)字小游戲(Swing版)

    java實(shí)現(xiàn)猜數(shù)字小游戲(Swing版)

    這篇文章主要介紹了java實(shí)現(xiàn)猜數(shù)字小游戲,Swing編程版的猜數(shù)字游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • MyBatis逆向?程的生成過程

    MyBatis逆向?程的生成過程

    MyBatis官方為我們提供了一個(gè)逆向工程,通過這個(gè)逆向工程,只要建立好數(shù)據(jù)表,那么MyBatis就會(huì)根據(jù)這個(gè)表自動(dòng)生成pojo類、dao接口、sql映射文件
    2023-02-02
  • 利用Spring框架為自己的校園卡充值(推薦)

    利用Spring框架為自己的校園卡充值(推薦)

    這篇文章主要介紹了利用Spring框架為自己的校園卡充值,本次實(shí)驗(yàn)主要運(yùn)用了Spring的控制反轉(zhuǎn)(IOC)和依賴注入(DI)等知識(shí),通過利用Spring框架編寫Java程序,實(shí)現(xiàn)學(xué)生卡的單次充值,如需對(duì)學(xué)生卡進(jìn)行多次充值,可將部分代碼修改即可實(shí)現(xiàn),需要的朋友可以參考下
    2022-10-10

最新評(píng)論