>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 지정된 문자에 따라 문자열을 분할하는 방법

MySQL에서 지정된 문자에 따라 문자열을 분할하는 방법

WBOY
WBOY앞으로
2023-06-03 14:00:134622검색

머리말

일부 시나리오(예: 사용자가 파일이나 사진 등을 업로드하는 경우)에서 일반적인 접근 방식은 파일 정보(파일 이름, 파일 경로, 파일 크기 등)를 파일 테이블(user_file)에 저장하는 것입니다. 그런 다음 사용자가 업로드한 모든 파일의 ID를 지정된 문자와 연결한 다음 테이블(사용자)의 필드에 저장합니다(file_ids로 가정).
사용자가 업로드한 파일을 표시할 때 파일 테이블을 직접 쿼리하면 됩니다.

-- 一般的语句是这样的,假设用户唯一键是id
select * from file where id in(select file_ids from user where id = 1);

sql 문에는 문제가 없으며 파일도 쿼리할 수 있습니다. 단, 업로드된 파일이 1개 이상인 후에는 이 sql 문을 사용합니다. 1개의 레코드만 반환한 후 혼란스러울 수 있는데 왜 하나의 레코드만 반환됩니까? ? ? ;

누군가 그런 확인을 했을 텐데

-- 先运行下面这个sql,正确返回1,2,3 假设上传的文件id是1,2,3;
select file_ids from user where id = 1
-- 然后返回的文件id写死在sql语句中,运行成功返回3条记录
select file_ids from user where id in ('1' , '2' , '3');
-- 最后再整体试了下,结果返回一条......
select * from file where id in(select file_ids from user where id = 1)

-- 然后可能会想到:我把in里面的拼接成'1','2','3',这样总可以了吧?
select * from file where id in (select concat('\'', replace(file_ids,',','\',\'') ,'\'') from user where id = 1);
-- concat('\'', replace(file_ids,',','\',\'') ,'\'') 确实能拼接成上面说的形式,但是结果还是只有一条

이유는 이 쿼리는 하나의 필드만 반환하기 때문에 하나의 레코드만 반환되기 때문입니다. (쉼표가 여러 개 이어져 있거나, 수동으로 이어져 있어도 Mysql은 이를 고려하기만 합니다.) 하나의 값이 되도록, 구체적으로 맨 아래 레이어가 명확하지 않습니다...) 올바른 접근 방식은 다음과 같습니다.

One: 두 번에 쿼리(이 글의 초점은 아니지만 구현 가능)

select file_ids from user where id = 1

select file_ids from user where id in ('1' , '2' , '3');
或者
select file_ids from user where find_in_set(id , '1,2,3');

Two : file_ids 필드를 여러 열로 분할합니다. 이는 Mysql의 행-열 변환

과 유사합니다. Mysql 행 변환과 열 변환의 차이점: 행을 열로 변환할 때 열의 내용을 알아야 할 필요는 없습니다.

-- 下面语句将会把1,2,3,4一个字段转换成四行,依次是1,2,3,4
SELECT
	a.id,
	a.file_ids,
	substring_index(
		substring_index(
			a.file_ids,
			',',
			b.help_topic_id + 1
		),
		',' ,- 1
	) file_id
FROM
	user a
JOIN mysql.help_topic b ON b.help_topic_id < (
	length(a.file_ids) - length(REPLACE(a.file_ids, &#39;,&#39;, &#39;&#39;)) + 1
)
where id = 1
;
-- 然后将上面语句写在in()里面就行了,写在in()里面的话记住只能查询一个字段哦!

위의 구문을 직접 복사할 수 있습니다. 테이블과 테이블 필드를 직접 입력하면 됩니다. 그러니 걱정하지 마세요.

첨부: mysql은 구분 기호로 문자열을 어떻게 분할합니까?

1. 문자열 분할: SUBSTRING_INDEX(압력 136/70 혈압), 예:

SUBSTRING_INDEX(pressure ,&#39;,&#39;,1)     #截取第一个逗号(,)号以前的字符串
SUBSTRING_INDEX(pressure ,&#39;,&#39;,-1)    #截取倒数第一个逗号(,)号以后的字符串

2 대체 함수: replacement(str, from_str, to_str). 예:

UPDATE bgs_building_copy1 SET `name`=replace(`name`,&#39;=&#39;,"");    #替换等号为空字符串

위 내용은 MySQL에서 지정된 문자에 따라 문자열을 분할하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제