1. 程式人生 > 程式設計 >JavaBean實體類處理外來鍵過程解析

JavaBean實體類處理外來鍵過程解析

資料庫中的表在對映為JavaBean的實體類時,實體類的欄位名應與資料庫表中的欄位名一致。那麼外來鍵要怎麼處理?

1. JavaBean中實體類中不應該出現外來鍵欄位,弊端如下 :

如果出現外來鍵對應的欄位,那麼將會出現一個物件與另一個物件的屬性相對應,這將不是面向物件中的物件與物件對應。

單個外來鍵只能儲存一個字串,用處不大

2.外來鍵處理方式 :資料庫表中的外來鍵欄位應當轉換成外來鍵對應的表的物件,也就是JavaBean的實體類不宣告外來鍵的欄位,而是宣告外來鍵對應資料表類的型別。舉個例子,如下 :

資料庫建表如下 :

-- 1.1 建立使用者表
CREATE TABLE `user` (
 `uid` varchar(32) NOT NULL,#使用者編號
 `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,#狀態:0=未啟用,1=已啟用
 `code` varchar(64) DEFAULT NULL,#啟用碼
 PRIMARY KEY (`uid`)
) ENGINE=InnoDB ;
 
-- 2.1 建立分類表
CREATE TABLE `category` (
 `cid` varchar(32) NOT NULL,`cname` varchar(20) DEFAULT NULL,#分類名稱
 PRIMARY KEY (`cid`)
) ENGINE=InnoDB ;
 
-- 3.1 建立商品表
CREATE TABLE `product` (
 `pid` varchar(32) NOT NULL,`pname` varchar(50) DEFAULT NULL,#商品名稱
 `market_price` double DEFAULT NULL,#市場價
 `shop_price` double DEFAULT NULL,#商城價
 `pimage` varchar(200) DEFAULT NULL,#商品圖片路徑
 `pdate` date DEFAULT NULL,#上架時間
 `is_hot` int(11) DEFAULT NULL,#是否熱門:0=不熱門,1=熱門
 `pdesc` varchar(255) DEFAULT NULL,#商品描述
 `pflag` int(11) DEFAULT 0,#商品標記:0=未下架(預設值),1=已經下架
 `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 建立訂單表
CREATE TABLE `order` (
 `oid` varchar(32) NOT NULL,`ordertime` datetime DEFAULT NULL,#下單時間
 `total` double DEFAULT NULL,#總價
 `state` int(11) DEFAULT NULL,#訂單狀態:1=未付款;2=已付款,未發貨;3=已發貨,沒收貨;4=收貨,訂單結束
 `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 建立訂單項表
CREATE TABLE `orderitem` (
 `itemid` varchar(32) NOT NULL,`quantity` int(11) DEFAULT NULL,#購買數量
 `total` double DEFAULT NULL,#小計
 `pid` varchar(32) DEFAULT NULL,#購買商品的id
 `oid` varchar(32) DEFAULT NULL,#訂單項所在訂單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 ;

其中訂單與訂單項的JavaBean的實體類如下 :

/**
 * 訂單項
 */
public class OrderItem {
 
  private String itemid ;   // 訂單項編號
  private Integer quantity;    // 購買數量
  private Double total;  // 小計
 
  private Product product ;  // 商品物件
  private Order order ;    // 訂單項所在訂單物件
  ......
}
 
/**
 * 訂單實體類
 */
public class Order {
   
  private String oid ;    // 訂單編號
  private Date ordertime; // 下單時間
  private Double total ;   // 總價
  private Integer state ;   // 訂單狀態 : 1 : 未付款 2 : 已付款,未發貨  3 :已發貨,未收貨  4: 已收貨,訂單結束
  private String address ;  // 收貨地址
  private String name ;    // 收件人姓名 : 收件人不一定是購買人
  private String telephone ; // 收件人電話
 
  private User user ;     // 訂單所屬的使用者
   
  private List<OrderItem> list = new ArrayList<>() ; // 訂單項集合
  ......
}

這樣做的優點如下 :

  • 程式物件和物件產生關係,而不是物件(Order的物件)和物件的屬性(User物件的uid)產生關係
  • 設計Order的目的 : 讓order攜帶訂單上的資料向service層,dao層傳遞,user物件是可以攜帶更多的資料的
  • 程式中體現訂單物件和訂單項物件之間的關係,專案中的部分功能中有類似的需求 : 查詢訂單的同時,還要獲取訂單下所有的訂單項

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。