中文字幕视频在线看,亚洲精品无码久久久久av老牛,亚洲精品无码av片,亚洲av影院一区二区三区,亚洲国产精品成人久久久

mysql合并字段內(nèi)容(mysql刪除某個(gè)字段)

1. 創(chuàng)建測(cè)試表及數(shù)據(jù)

-- 創(chuàng)建一張tb_stu表
CREATE TABLE tb_user(
id INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(10) COMMENT '人名',
c_no VARCHAR(64) COMMENT '持劍ID,以逗號(hào)分隔'
);
INSERT INTO tb_user(NAME,c_no) VALUES('蘧伯玉','1,3,5,7');
INSERT INTO tb_user(NAME,c_no) VALUES('高漸離','1,2,4,8,5');
INSERT INTO tb_user(NAME,c_no) VALUES('樗里疾','2,9');
INSERT INTO tb_user(NAME,c_no) VALUES('澹臺(tái)滅明','1,2');
INSERT INTO tb_user(NAME,c_no) VALUES('鐘子期','1,2,6,8,7,3,5');
INSERT INTO tb_user(NAME,c_no) VALUES('柳下惠','2,4,3,5');
INSERT INTO tb_user(NAME,c_no) VALUES('百里奚','1,9');
INSERT INTO tb_user(NAME,c_no) VALUES('闞止','1,6,7');
INSERT INTO tb_user(NAME,c_no) VALUES('霍去病','1,8,5');
INSERT INTO tb_user(NAME,c_no) VALUES('慕容白曜','1,2,3,4,5,7');
INSERT INTO tb_user(NAME,c_no) VALUES('魚幼薇','7,8,9');
INSERT INTO tb_user(NAME,c_no) VALUES('宋玉','6,5');
-- 創(chuàng)建一張劍名
create table tb_sword(
id int primary key AUTO_INCREMENT,
c_name varchar(4)) comment '劍名';
insert into tb_sword(c_name)values('軒轅');
insert into tb_sword(c_name)values('湛盧');
insert into tb_sword(c_name)values('赤霄');
insert into tb_sword(c_name)values('太阿');
insert into tb_sword(c_name)values('七星龍淵');
insert into tb_sword(c_name)values('干將');
insert into tb_sword(c_name)values('莫邪');
insert into tb_sword(c_name)values('魚腸');
insert into tb_sword(c_name)values('純鈞');

兩張表內(nèi)容如下:

tb_user

mysql合并字段內(nèi)容(mysql刪除某個(gè)字段)

tb_sword

mysql合并字段內(nèi)容(mysql刪除某個(gè)字段)

2. 數(shù)據(jù)拆分及合并

需求: 使用一條SQL獲得tb_user表中每個(gè)人持有的劍名(劍名用“|”分隔),即得到如下結(jié)果

mysql合并字段內(nèi)容(mysql刪除某個(gè)字段)

拆解需求:

1) 先將tb_user表中的c_no按逗號(hào)拆分

2)將拆分后c_no中的各個(gè)id與tb_sword中的id關(guān)聯(lián),獲取劍名

3) 最后將每一個(gè)user對(duì)應(yīng)的劍名合并成一個(gè)字段

分段SQL如下:

步驟1:

每一個(gè)user的c_no按逗號(hào)拆分為對(duì)應(yīng)的c_id,此方法需借助于mysql.help_topic表

SELECT a.id,a.name,a.c_no, SUBSTRING_INDEX( SUBSTRING_INDEX( a.c_no, ',', b.help_topic_id + 1 ), ',',- 1 ) c_id
FROM tb_user a JOIN mysql.help_topic b ON b.help_topic_id < ( LENGTH( a.c_no ) - LENGTH( REPLACE ( a.c_no, ',', '' ) ) + 1 )
ORDER BY a.id

結(jié)果如下:

mysql合并字段內(nèi)容(mysql刪除某個(gè)字段)

步驟2:關(guān)聯(lián)獲取每個(gè)id對(duì)應(yīng)的劍名

SELECT a2.id,a2.name,a2.c_no,a2.c_id,b2.c_name
FROM (
SELECT a.id,a.name,a.c_no, SUBSTRING_INDEX( SUBSTRING_INDEX( a.c_no, ',', b.help_topic_id + 1 ), ',',- 1 ) c_id
FROM tb_user a JOIN mysql.help_topic b ON b.help_topic_id < ( LENGTH( a.c_no ) - LENGTH( REPLACE ( a.c_no, ',', '' ) ) + 1 )
ORDER BY a.id
) a2, -- a2表即步驟1中拆分的結(jié)果
tb_sword b2 WHERE a2.c_id =b2.id -- 關(guān)聯(lián),相當(dāng)于inner join(或者join)

結(jié)果如下

mysql合并字段內(nèi)容(mysql刪除某個(gè)字段)

步驟3:

將每個(gè)人的劍名合并為1個(gè)字段顯示,并用”|” 符合合并

SELECT a2.id,a2.name,a2.c_no,
GROUP_CONCAT(b2.c_name SEPARATOR '|' ) sword_name
-- SEPARATOR 指定分隔富,不加默認(rèn)為逗號(hào)分隔
FROM (SELECT a.id,a.name,a.c_no,
SUBSTRING_INDEX( SUBSTRING_INDEX( a.c_no, ',', b.help_topic_id + 1 ), ',',- 1 ) c_id
FROM tb_user a
JOIN mysql.help_topic b ON b.help_topic_id < ( LENGTH( a.c_no ) - LENGTH( REPLACE ( a.c_no, ',', '' ) ) + 1 )
ORDER BY a.id) a2,tb_sword b2
WHERE a2.c_id =b2.id
GROUP BY a2.id

結(jié)果如下:

mysql合并字段內(nèi)容(mysql刪除某個(gè)字段)

實(shí)現(xiàn)需求

版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn),該文觀點(diǎn)僅代表作者本人。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請(qǐng)發(fā)送郵件至2705686032@qq.com 舉報(bào),一經(jīng)查實(shí),本站將立刻刪除。原文轉(zhuǎn)載: 原文出處:

(0)
尊云-小張的頭像尊云-小張
上一篇 2024 年 5 月 22 日 09:28
下一篇 2024 年 5 月 22 日 09:38

相關(guān)推薦

發(fā)表回復(fù)

登錄后才能評(píng)論

聯(lián)系我們

400-900-3935

在線咨詢: QQ交談

郵件:cong@zun.com

工作時(shí)間:365天無(wú)休服務(wù) 24小時(shí)在線

添加微信