触发器初接触-同步两个表的指定字段
生活随笔
收集整理的這篇文章主要介紹了
触发器初接触-同步两个表的指定字段
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
博客已經申請5個月了,= = 到現在一篇隨筆都沒寫過。那就寫寫吧。
前幾天,一位朋友說他有個需求:同步兩個表的指定字段,問有什么辦法。后來用觸發器來實現了下,之前也沒寫過,所以還是在這里記錄下吧。
需求: 有表 tp_userinfo ,ims_card_members? 其中對應關聯字段為 credit1 《=》total_score
??????就是說 表?tp_userinfo的credit1字段更新時,表ims_card_members對應的total_score也需要更新;反正亦然。
解決: 為兩個表創建觸發器,字段更新時另一個表的對應字段。
注意的地方:因為相互觸發,所以update前注意判斷內容是否變動過,不然就是死循環了。
?
小白寫代碼mysql 實現:
drop trigger if exists tp_userinfo_trigger; -- tp_userinfo trigger create trigger tp_userinfo_trigger after UPDATEon tp_userinfo for each row begin set @credit1 = (select credit1 from ims_card_members where old.wecha_id = from_user limit 1); IF(@credit1 <> new.total_score) THENupdate ims_card_members set credit1 = new.total_score where from_user = old.wecha_id;end if;end;drop trigger if exists ims_card_members_trigger; -- ims_card_members triggercreate trigger ims_card_members_trigger after UPDATEon ims_card_members for each row begin set @total_score = (select total_score from tp_userinfo where wecha_id = old.from_user limit 1); IF(@total_score <> new.credit1) THENupdate tp_userinfo set total_score = new.credit1 where wecha_id = old.from_user;end if;end;?
轉載于:https://www.cnblogs.com/jeffreyluo/p/4780767.html
總結
以上是生活随笔為你收集整理的触发器初接触-同步两个表的指定字段的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Count Complete Tree
- 下一篇: iOS-本地推送和远程推送,常用的三方推