亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

查找_IN_set()vs IN()

查找_IN_set()vs IN()

MMMHUHU 2019-06-29 18:05:45
查找_IN_set()vs IN()我的數據庫里有兩張桌子。一個是訂單,一個是公司。訂單的結構如下:OrderID     |     attachedCompanyIDs------------------------------------    1                     1,2,3    2                     2,4公司有這樣的結構:CompanyID      |        name--------------------------------------     1                 Company 1     2                 Another Company    3                 StackOverflow    4                 Nothing要獲得訂單的公司名稱,我可以這樣進行查詢:SELECT name FROM orders,companyWHERE orderID = 1 AND FIND_IN_SET(companyID, attachedCompanyIDs)該查詢工作正常,但下面的查詢不工作。SELECT name FROM orders,companyWHERE orderID = 1 AND companyID IN (attachedCompanyIDs)為什么第一個查詢工作,而不是第二個查詢?第一個查詢返回:name---------------Company 1Another Company StackOverflow第二個查詢只返回:name---------------Company 1為什么第一個查詢返回所有公司,而第二個查詢只返回第一個查詢?
查看完整描述

3 回答

?
墨色風雨

TA貢獻1853條經驗 獲得超6個贊

附件CompanyID是一個大字符串,因此MySQL試圖在其中找到它的轉換為整數的公司。

當你使用WHERE

所以如果comapnyid=1:

companyID IN ('1,2,3')

這是返回真

但如果數字1不是第一位

 companyID IN ('2,3,1')

其返回為假


查看完整回答
反對 回復 2019-06-29
?
忽然笑

TA貢獻1806條經驗 獲得超5個贊

獲取所有相關公司的名稱,而不是基于特定的ID。

SELECT 
    (SELECT GROUP_CONCAT(cmp.cmpny_name) 
    FROM company cmp 
    WHERE FIND_IN_SET(cmp.CompanyID, odr.attachedCompanyIDs)
    ) AS COMPANIESFROM orders odr


查看完整回答
反對 回復 2019-06-29
  • 3 回答
  • 0 關注
  • 407 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號