집 >데이터 베이스 >MySQL 튜토리얼 >MySQL에서 지정된 문자에 따라 문자열을 분할하는 방법
일부 시나리오(예: 사용자가 파일이나 사진 등을 업로드하는 경우)에서 일반적인 접근 방식은 파일 정보(파일 이름, 파일 경로, 파일 크기 등)를 파일 테이블(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은 이를 고려하기만 합니다.) 하나의 값이 되도록, 구체적으로 맨 아래 레이어가 명확하지 않습니다...) 올바른 접근 방식은 다음과 같습니다.
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');
과 유사합니다. 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, ',', '')) + 1 ) where id = 1 ; -- 然后将上面语句写在in()里面就行了,写在in()里面的话记住只能查询一个字段哦!
위의 구문을 직접 복사할 수 있습니다. 테이블과 테이블 필드를 직접 입력하면 됩니다. 그러니 걱정하지 마세요.
1. 문자열 분할: SUBSTRING_INDEX(압력 136/70 혈압), 예:
SUBSTRING_INDEX(pressure ,',',1) #截取第一个逗号(,)号以前的字符串 SUBSTRING_INDEX(pressure ,',',-1) #截取倒数第一个逗号(,)号以后的字符串
2 대체 함수: replacement(str, from_str, to_str). 예:
UPDATE bgs_building_copy1 SET `name`=replace(`name`,'=',""); #替换等号为空字符串
위 내용은 MySQL에서 지정된 문자에 따라 문자열을 분할하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!