JavaBean實體類處理外來鍵過程解析
阿新 • • 發佈:2020-07-31
資料庫中的表在對映為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物件是可以攜帶更多的資料的
- 程式中體現訂單物件和訂單項物件之間的關係,專案中的部分功能中有類似的需求 : 查詢訂單的同時,還要獲取訂單下所有的訂單項
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。