>데이터 베이스 >MySQL 튜토리얼 >관련 변수 조건 수정, mysql에서 한 줄에 데이터 쿼리 및 표시 소개

관련 변수 조건 수정, mysql에서 한 줄에 데이터 쿼리 및 표시 소개

不言
不言앞으로
2018-10-20 17:09:502663검색

이 기사에서는 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

관련 변수 조건 수정, mysql에서 한 줄에 데이터 쿼리 및 표시 소개

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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