JavaBean實(shí)體類處理外鍵過程解析
數(shù)據(jù)庫中的表在映射為JavaBean的實(shí)體類時,實(shí)體類的字段名應(yīng)與數(shù)據(jù)庫表中的字段名一致。那么外鍵要怎么處理?
1. JavaBean中實(shí)體類中不應(yīng)該出現(xiàn)外鍵字段,弊端如下 :
如果出現(xiàn)外鍵對應(yīng)的字段,那么將會出現(xiàn)一個對象與另一個對象的屬性相對應(yīng),這將不是面向?qū)ο笾械膶ο笈c對象對應(yīng)。
單個外鍵只能存儲一個字符串,用處不大
2.外鍵處理方式 :數(shù)據(jù)庫表中的外鍵字段應(yīng)當(dāng)轉(zhuǎn)換成外鍵對應(yīng)的表的對象,也就是JavaBean的實(shí)體類不聲明外鍵的字段,而是聲明外鍵對應(yīng)數(shù)據(jù)表類的類型。舉個例子,如下 :
數(shù)據(jù)庫建表如下 :
-- 1.1 創(chuàng)建用戶表 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, #狀態(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, #市場價(jià) `shop_price` double DEFAULT NULL, #商城價(jià) `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, #商品標(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, #下單時間 `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, #購買數(shù)量 `total` double DEFAULT NULL, #小計(jì) `pid` varchar(32) DEFAULT NULL, #購買商品的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)編號
private Integer quantity; // 購買數(shù)量
private Double total; // 小計(jì)
private Product product ; // 商品對象
private Order order ; // 訂單項(xiàng)所在訂單對象
......
}
/**
* 訂單實(shí)體類
*/
public class Order {
private String oid ; // 訂單編號
private Date ordertime; // 下單時間
private Double total ; // 總價(jià)
private Integer state ; // 訂單狀態(tài) : 1 : 未付款 2 : 已付款,未發(fā)貨 3 :已發(fā)貨,未收貨 4: 已收貨,訂單結(jié)束
private String address ; // 收貨地址
private String name ; // 收件人姓名 : 收件人不一定是購買人
private String telephone ; // 收件人電話
private User user ; // 訂單所屬的用戶
private List<OrderItem> list = new ArrayList<>() ; // 訂單項(xiàng)集合
......
}
這樣做的優(yōu)點(diǎn)如下 :
- 程序?qū)ο蠛蛯ο螽a(chǎn)生關(guān)系,而不是對象(Order的對象)和對象的屬性(User對象的uid)產(chǎn)生關(guān)系
- 設(shè)計(jì)Order的目的 : 讓order攜帶訂單上的數(shù)據(jù)向service層,dao層傳遞,user對象是可以攜帶更多的數(shù)據(jù)的
- 程序中體現(xiàn)訂單對象和訂單項(xiàng)對象之間的關(guān)系,項(xiàng)目中的部分功能中有類似的需求 : 查詢訂單的同時,還要獲取訂單下所有的訂單項(xiàng)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java如何實(shí)現(xiàn)Unicode和中文相互轉(zhuǎn)換
這篇文章主要介紹了Java如何實(shí)現(xiàn)Unicode和中文相互轉(zhuǎn)換問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01
詳解SpringBoot中的參數(shù)校驗(yàn)(項(xiàng)目實(shí)戰(zhàn))
這篇文章主要介紹了SpringBoot中的參數(shù)校驗(yàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
Java利用布隆過濾器實(shí)現(xiàn)快速檢查元素是否存在
布隆過濾器是一個很長的二進(jìn)制向量和一系列隨機(jī)映射函數(shù)。布隆過濾器可以用于檢索一個元素是否在一個集合中。本文就來詳細(xì)說說實(shí)現(xiàn)的方法,需要的可以參考一下2022-10-10
Spring Boot開箱即用可插拔實(shí)現(xiàn)過程演練與原理解析
本文通過深入探討Spring Boot的背景歷史、業(yè)務(wù)場景、功能點(diǎn)以及底層原理,并通過Java代碼手寫模擬了Spring Boot的啟動過程和自動配置功能,為開發(fā)者提供了一個全面的理解,感興趣的朋友跟隨小編一起看看吧2024-11-11
Spring Boot超詳細(xì)講解請求處理流程機(jī)制
SpringBoot是一種整合Spring技術(shù)棧的方式(或者說是框架),同時也是簡化Spring的一種快速開發(fā)的腳手架,本篇讓我們一起分析請求處理流程機(jī)制2022-07-07
java Quartz定時器任務(wù)與Spring task定時的幾種實(shí)現(xiàn)方法
本篇文章主要介紹了java Quartz定時器任務(wù)與Spring task定時的幾種實(shí)現(xiàn)方法的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-02-02
解讀Jvm的內(nèi)存結(jié)構(gòu)與GC及jvm參數(shù)調(diào)優(yōu)
這篇文章主要介紹了解讀Jvm的內(nèi)存結(jié)構(gòu)與GC及jvm參數(shù)調(diào)優(yōu)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05

