第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

查找_IN_set()vs IN()

查找_IN_set()vs IN()

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

3 回答

?
墨色風(fēng)雨

TA貢獻(xiàn)1853條經(jīng)驗(yàn) 獲得超6個(gè)贊

附件CompanyID是一個(gè)大字符串,因此MySQL試圖在其中找到它的轉(zhuǎn)換為整數(shù)的公司。

當(dāng)你使用WHERE

所以如果comapnyid=1:

companyID IN ('1,2,3')

這是返回真

但如果數(shù)字1不是第一位

 companyID IN ('2,3,1')

其返回為假


查看完整回答
反對(duì) 回復(fù) 2019-06-29
?
忽然笑

TA貢獻(xiàn)1806條經(jīng)驗(yàn) 獲得超5個(gè)贊

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

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


查看完整回答
反對(duì) 回復(fù) 2019-06-29
  • 3 回答
  • 0 關(guān)注
  • 412 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)