溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

mysql查詢結(jié)果怎么實(shí)現(xiàn)多列拼接查詢

發(fā)布時(shí)間:2022-04-06 10:49:27 來源:億速云 閱讀:331 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“mysql查詢結(jié)果怎么實(shí)現(xiàn)多列拼接查詢”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡單快捷,實(shí)用性強(qiáng),希望這篇“mysql查詢結(jié)果怎么實(shí)現(xiàn)多列拼接查詢”文章能幫助大家解決問題。

之前遇到過一個(gè)問題,mysql數(shù)據(jù)庫中有兩個(gè)表,一張地址表存放省市區(qū)等位置信息,另一張用戶表里存在三個(gè)字段分別對(duì)應(yīng)地址表中的三個(gè)位置信息(很奇怪的表格式),如圖:

mysql查詢結(jié)果怎么實(shí)現(xiàn)多列拼接查詢

mysql查詢結(jié)果怎么實(shí)現(xiàn)多列拼接查詢

現(xiàn)在需要查詢user表中的數(shù)據(jù),并根據(jù)user表中省市區(qū)的值,在地址表中查詢到對(duì)應(yīng)的位置信息(name)并顯示出來;

本人對(duì)sql并不精通,所以捋了一個(gè)大致邏輯

首先要得到user表的省市區(qū)三個(gè)字段的值,我們一般的查詢方式是

SELECT province,city,district FROM `user` WHERE id =1;

這個(gè)比較簡單,得到的結(jié)果為一行三列的值,如圖:

mysql查詢結(jié)果怎么實(shí)現(xiàn)多列拼接查詢

這是正常的寫法,之后使用這個(gè)結(jié)果為查詢條件,去查詢地址表中的name即可.

當(dāng)然想法似乎不錯(cuò),但這個(gè)查詢出來的結(jié)果是分為三段的,并不利于我們后面的查詢,總不能取出結(jié)果后再進(jìn)行處理再查詢吧,這樣太麻煩了,這時(shí)候要用到sql的兩個(gè)函數(shù),CONCAT_WS和CONCAT,兩個(gè)函數(shù)的作用是將結(jié)果拼接為一個(gè)字符串,具體的用法可以自行百度.這里就不多做介紹了:)

所以我們的查詢語句就可以寫成SELECT CONCAT_WS(',',province,city,district) AS ids FROM `user` WHERE id =1;得到的結(jié)果如圖:

mysql查詢結(jié)果怎么實(shí)現(xiàn)多列拼接查詢

有了這個(gè)結(jié)果我們基本上可以去查詢到地址信息了,同樣的在查詢地址信息的時(shí)候我們也做了相應(yīng)的拼接,所以最終的sql是這樣的

SELECT GROUP_CONCAT(`name`) FROM address WHERE id IN (SELECT CONCAT_WS(',',province,city,district) FROM `user` WHERE id =1);

理想中的結(jié)果如圖:

mysql查詢結(jié)果怎么實(shí)現(xiàn)多列拼接查詢

但實(shí)際上,這個(gè)語句并不能得到我們想要的結(jié)果,原因是SELECT CONCAT_WS(',',province,city,district) FROM `user` WHERE id =1查詢出的結(jié)果是一個(gè)字符串,而字符串卻不能作為查詢條件中In的條件來使用,所以查詢的結(jié)果并不是我們想要的.

再分析下我們的思路并沒有問題,那么怎么才能用這個(gè)字符串作為查詢條件,并最終得出我們想要的結(jié)果呢?根據(jù)網(wǎng)上的資料得知,查詢條件in的內(nèi)容只能是數(shù)字型的,所以他并不支持字符串的查詢,所以這里我們還需要一個(gè)函數(shù),instr.說實(shí)話這也是我第一次知道這個(gè)函數(shù),畢竟對(duì)mysql真的只是會(huì)一點(diǎn)增刪改查的皮毛,哈哈.那么接下來我們來試試這個(gè)函數(shù)的效果,最終的sql為

SELECT
  GROUP_CONCAT(`name`)
FROM
  address
WHERE INSTR(
    (SELECT
      CONCAT_WS(',', province, city, district)
    FROM
      `user`
    WHERE id = 1),
    id
  ) ;

執(zhí)行后的結(jié)果也是我們想要的.當(dāng)然上邊的語句只是實(shí)現(xiàn)了查找到地址的結(jié)果,具體的可以根據(jù)業(yè)務(wù)需求繼續(xù)修改,mysql的函數(shù)不得不說確實(shí)很強(qiáng)大.今后還是要多學(xué)習(xí)才是;

所以,最終的sql為:

SELECT
  GROUP_CONCAT(`name`)
FROM
  address
WHERE INSTR(
    CONCAT(
      ',',
      (SELECT
        CONCAT_WS(',', province, city, district)
      FROM
        `user`
      WHERE id = 1),
      ','
    ),
    CONCAT(',', id, ',')
  ) ;

關(guān)于“mysql查詢結(jié)果怎么實(shí)現(xiàn)多列拼接查詢”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI