mysql中where+if判斷

來源:互聯網
上載者:User

在mysql中where中多重條件if判斷,項目需求如下:
好友關係中本身具有A,B,C三種角色,社交動向更新分為1,2,3,4,5種類型。A是必須具有的角色,如果具有A角色可查社交動向更新類型1,3,4 的資訊如果具有B角色可查2類型資訊,如果具有C角色可查5類型角色。
實現思想如下:先查出好友關係所有動態資料-》判斷B角色增加篩選2類型-》判斷C角色增加篩選5類型
下面說說實現步聚,具體添加的資料不在這裡說明了。
1.增加關係表

SQL Code複製內容到剪貼簿
  1. --  
  2. -- 表的結構 `表A`  
  3. --  
  4.   
  5. CREATE TABLE IF NOT EXISTS `表A` (  
  6.   `uid` int(11) NOT NULL AUTO_INCREMENT COMMENT '關注ID',  
  7.   `user_id` int(11) NOT NULL COMMENT '使用者名稱ID',  
  8.   `user_follow_id` int(11) NOT NULL COMMENT '被關注使用者ID',  
  9.   `iscarer` tinyint(2) NOT NULL DEFAULT '0' COMMENT '角色A關注為好友1是0否2忽略',  
  10.   `ishelper` tinyint(2) NOT NULL DEFAULT '0' COMMENT '角色B關注師傅1是0否2忽略',  
  11.   `issupplier` tinyint(2) NOT NULL DEFAULT '0' COMMENT '角色C關注服務商1是0否2忽略',  
  12.   `insert_time` varchar(20) NOT NULL COMMENT '增加時間',  
  13.   PRIMARY KEY (`uid`)  
  14. ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COMMENT='使用者關係關注表' AUTO_INCREMENT=21 ;  

2.增加社交動向更新表

SQL Code複製內容到剪貼簿
  1. --  
  2. -- 表的結構 `表B`  
  3. --  
  4.   
  5. CREATE TABLE IF NOT EXISTS `表B` (  
  6.   `uid` int(11) NOT NULL AUTO_INCREMENT COMMENT '訊息ID',  
  7.   `type` tinyint(4) NOT NULL COMMENT '用類型 1車主文章2,關注文章,3提問,4,調查,5訂單資訊',  
  8.   `user_id` int(11) NOT NULL ,  
  9.   `event_message` text NOT NULL COMMENT '動態資料序列化',  
  10.   `insert_time` varchar(20) NOT NULL,  
  11.   PRIMARY KEY (`uid`)  
  12. ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COMMENT='社交動向更新表' AUTO_INCREMENT=3 ;  

3.社交動向更新總記錄如下:
sql如下:

SQL Code複製內容到剪貼簿
  1. SELECT  
  2.     *  
  3. FROM  
  4.     表A f  
  5. LEFT JOIN(  
  6.     SELECT  
  7.         type,  
  8.         user_id AS author_id,  
  9.         event_message  
  10.     FROM  
  11.         表B 
  12. )e ON f.user_follow_id = e.author_id  
  13. WHERE  
  14. user_id = 275  
  15. AND iscarer = 1  
  16. AND type IS NOT NULL  

結果3條資料如下:

4.加上B角色去判斷sql如下:

SQL Code複製內容到剪貼簿
  1. SELECT  
  2.     *  
  3. FROM  
  4.     表A f  
  5. LEFT JOIN(  
  6.     SELECT  
  7.         type,  
  8.         user_id AS author_id,  
  9.         event_message  
  10.     FROM  
  11.         表B 
  12. )e ON f.user_follow_id = e.author_id  
  13. WHERE  
  14. IF(ishelper = 0, type <> 2, '1=1')  
  15. AND user_id = 275  
  16. AND iscarer = 1  
  17. AND type IS NOT NULL  

結果2條資料如下:

4.加上C角色去判斷sql如下:

SQL Code複製內容到剪貼簿
  1. SELECT  
  2.     *  
  3. FROM  
  4.     表A f  
  5. LEFT JOIN(  
  6.     SELECT  
  7.         type,  
  8.         user_id AS author_id,  
  9.         event_message  
  10.     FROM  
  11.         表B 
  12. )e ON f.user_follow_id = e.author_id  
  13. WHERE  
  14.   
  15. IF(ishelper = 0, type <> 2, '1=1')  
  16. AND  
  17. IF(issupplier = 0, type <>5, '1=1')  
  18. AND user_id = 275  
  19. AND iscarer = 1  
  20. AND type IS NOT NULL  

結果1條資料如下:

好了,達到了想要的效果了。
PS:後面where是可以根據索引值來條件先後順序

SQL Code複製內容到剪貼簿
  1. WHERE  
  2. user_id = 275  
  3. AND iscarer = 1  
  4. AND type IS NOT NULL  
  5. AND  
  6. IF(ishelper = 0, type <> 2, '1=1')  
  7. AND  
  8. IF(issupplier = 0, type <>5, '1=1')  
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.