동일 테이블 형제의 데이터로 행 업데이트
다음과 유사한 구조의 테이블을 상상해 보세요.
ID | NAME | VALUE |
---|---|---|
1 | Test | VALUE1 |
2 | Test2 | VALUE2 |
1 | Test2 | NULL |
4 | Test | NULL |
1 | Test3 | VALUE3 |
귀하의 작업은 동일한 "NAME"을 포함하는 다른 행의 데이터로 NULL "VALUE" 셀을 채우는 것입니다(즉, "Test" 및 "Test2"는 이전 행의 값을 상속해야 합니다). 원하는 결과는 다음과 같습니다.
ID | NAME | VALUE |
---|---|---|
1 | Test | VALUE1 |
2 | Test2 | VALUE2 |
1 | Test2 | VALUE2 |
4 | Test | VALUE1 |
1 | Test3 | VALUE3 |
이 문제는 특정 "NAME" 값을 공유하는 동일한 테이블 내의 행을 참조하는 데 있습니다. 해결 방법은 JOIN 문을 사용하는 것입니다.
UPDATE data_table t, (SELECT DISTINCT ID, NAME, VALUE FROM data_table WHERE VALUE IS NOT NULL AND VALUE != '') t1 SET t.VALUE = t1.VALUE WHERE t.ID = t1.ID AND t.NAME = t1.NAME
이 문에서 하위 쿼리(T1)는 NULL이 아니고 비어 있지 않은 "VALUE" 값이 있는 고유 행을 추출합니다. 그런 다음 기본 쿼리(t)는 "ID" 및 "NAME" 필드에서 이 하위 쿼리와 조인되어 업데이트할 행을 식별합니다. 결과적으로 빈 "VALUE" 셀은 동일한 "NAME" 값을 가진 비어 있지 않은 행의 해당 값으로 채워집니다.
위 내용은 동일한 이름을 공유하는 행의 데이터로 테이블의 NULL 값을 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!