文章詳情頁
java - 關聯表修改一般怎么做
瀏覽:121日期:2022-06-13 13:26:45
問題描述
屬性表 attr商品表 item關聯表 item_attr
屬性表字段cat_id、title
商品表表字段item_id、title
商品表表字段item_attr_id、item_id、attr_id
比如屬性有5條記錄,cat_id分別是1、2、3、4、5添加一個商品,選擇了屬性2、5
那么關聯表應該就是兩條記錄,現在如果要修改,比如去掉5增加4,這樣一般這么處理
我現在是先獲取 原來的舊 attr_id,一個一個去查找看新 attr_id 有沒有,如果沒有就刪除,再循環新attr_id一個一個查找就的 attr_id里面有沒有,如果有跳過,沒有就添加
有更好的方法沒,一開始我想法是先全部刪除,再吧新的添加,這樣是不是不科學
問題解答
回答1:關聯表應該就是庫存表。一個商品+一個屬性,定義一個庫存。你上面說的遍歷之后,比對之后,有變動就修改,沒有就刪除,這個是對的。
回答2:你后面說的是科學的,前面講的太復雜,那才不科學。關聯表中先根據item_id全部刪除,再全部添加delete from item_attr where item_id = 1;insert into item_attr (item_id、attr_id) values (1, 1), (1, 2), (1, 2);這種效率最高
回答3:全部刪除,再根據最新的全部添加。邏輯簡單,效率最好
相關文章:
1. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處2. javascript - ios返回不執行js怎么解決?3. python - 爬蟲模擬登錄后,爬取csdn后臺文章列表遇到的問題4. 視頻文件不能播放,怎么辦?5. python bottle跑起來以后,定時執行的任務為什么每次都重復(多)執行一次?6. html5 - HTML代碼中的文字亂碼是怎么回事?7. javascript - 求幫助 , ATOM不顯示界面!!!!8. mysql 查詢身份證號字段值有效的數據9. javascript - angular使從elastichearch中取出的文本高亮顯示,如圖所示10. javascript - 為什么在谷歌控制臺 輸出1的時候,輸出的1立馬就不見了
排行榜
