> 데이터 베이스 > MySQL 튜토리얼 > 동일한 이름을 공유하는 행의 데이터로 테이블의 NULL 값을 업데이트하는 방법은 무엇입니까?

동일한 이름을 공유하는 행의 데이터로 테이블의 NULL 값을 업데이트하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-11-12 19:43:02
원래의
348명이 탐색했습니다.

How to Update NULL Values in a Table with Data from Rows Sharing the Same Name?

동일 테이블 형제의 데이터로 행 업데이트

다음과 유사한 구조의 테이블을 상상해 보세요.

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿