집 >데이터 베이스 >MySQL 튜토리얼 >관련 변수 조건 수정, mysql에서 한 줄에 데이터 쿼리 및 표시 소개
이 기사에서는 MySQL에서 관련 변수 조건을 수정하고 데이터를 한 줄에 표시하는 방법(코드 포함)을 소개합니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다. 도움이되었습니다.
일대다 데이터가 한 행에 표시됩니다
GROUP_CONCAT(expr)
1. 관련 테이블 관계: 교사 테이블, Teacher_subject_rel 테이블(교사가 가르칠 수 있는 과목 테이블), 과목 테이블
2. : 필수 모든 선생님의 번호(teacher_no)와 과목명(subject_name)을 가져옵니다.   교사 테이블(teacher)과 과목(teacher_subject_rel)은 일대다 관계를 갖습니다. 동일한 교사에 대한 여러 데이터가 쿼리에 나타나는 경우가 있습니다. 각 교사의 데이터 주제를 하나로 엮기를 바랍니다
1. 기본 구문
group_concat( [DISTINCT] 연결할 필드 [Order BY sorting field ASC/DESC] [Separator 'separator'] )
2 , 예시
SELECT t.teacher_id as '教师id', t.teacher_no '教师编号', ( SELECT GROUP_CONCAT(s.subject_name) FROM teacher_subject_rel tsr LEFT JOIN `subject` s ON tsr.subject_id = s.subject_id WHERE t.teacher_id = tsr.teacher_id ) AS '学科' FROM teacher t
Subquery, 임시 테이블 쿼리, EXISTS
Example
SELECT * FROM ( SELECT o.id, o.student_intention_id, s. NAME, s.area_id, a.area_name, s.exam_year, o. STATUS, CASE o. STATUS WHEN '1' THEN '待提交' WHEN '2' THEN '待指派' WHEN '3' THEN '已完成' WHEN '4' THEN '处理中' END statusName, CASE o.emergency_degree WHEN '1' THEN '正常' WHEN '2' THEN '紧急' WHEN '3' THEN '非常紧急' END emergencyDegreeName, o.emergency_degree, o.update_time, ( SELECT first_lesson_time FROM jx_strategy WHERE jx_lesson_plan_order_id = o.id AND STATUS IN (2, 7) AND first_lesson_time > now() ORDER BY first_lesson_time ASC LIMIT 1 ) AS first_time, ( SELECT deal_user_id FROM jx_strategy WHERE jx_lesson_plan_order_id = o.id AND STATUS 7 AND deal_user_id 0 ORDER BY id DESC LIMIT 1 ) AS deal_user_id FROM jx_lesson_plan_order o LEFT JOIN student s ON s.student_intention_id = o.student_intention_id LEFT JOIN area a ON s.area_id = a.id WHERE o. STATUS 1 AND s.phone = '18501665888' AND o.emergency_degree = 1 AND o. STATUS = 2 AND s.exam_year = '2015' AND o.update_time >= '2018-08-14 20:28:55' AND o.update_time = '2018-08-17 00:00:00' AND a.first_time <p><strong>update 관련 변수 조건 수정</strong></p><p>1. _정보 테이블 번호) Teacher 테이블의 출생 필드, 연관 관계 usrer_id = Teacher_id<br>2. 비즈니스 시나리오: 사용자 ID 카드의 생년월일을 가져오고 출생 필드의 생년월일을 업데이트합니다</p><pre class="brush:php;toolbar:false">UPDATE teacher t INNER JOIN ( SELECT t.teacher_id, t.birth, u.id_number, CONCAT(SUBSTRING(u.id_number, 7, 4), '-', SUBSTRING(u.id_number, 11, 2), '-', SUBSTRING(u.id_number, 13, 2)) as birth1, u.reg_date, t.exit_time from teacher t INNER JOIN user_info u ON u.user_id = t.teacher_id ) info on info.teacher_id = t.teacher_id SET t.birth = info.birth1 WHERE info.reg_date > '2018-08-20 00:00:00' and info.id_number is not NULL and (info.birth is NULL or t.birth = '') and t.is_train = 1
위 내용은 관련 변수 조건 수정, mysql에서 한 줄에 데이터 쿼리 및 표시 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!