"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 동일한 이름을 공유하는 행의 데이터로 테이블의 NULL 값을 업데이트하는 방법은 무엇입니까?

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

2024년 11월 18일에 게시됨
검색:897

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

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

다음과 유사한 구조로 테이블을 구상합니다. 이:

ID이름
1테스트VALUE1
2테스트2VALUE2
1테스트2NULL
4테스트NULL
1테스트3VALUE3

귀하의 작업은 NULL "VALUE" 셀을 동일한 "NAME"을 포함하는 다른 행의 데이터로 채우는 것입니다(즉, "Test" 및 "Test2"는 이전 항목의 값을 상속해야 합니다). 원하는 결과 상태:

ID이름값1테스트VALUE12테스트2VALUE21테스트2VALUE24테스트VALUE11테스트3VALUE3

문제는 특정 "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
UPDATE data_table t, (SELECT DISTINCT ID, NAME, VALUE data_table에서 값이 NULL이 아니고 값이 != '') t1인 경우 t.값 설정 = t1.값 여기서 t.ID = t1.ID AND t.NAME = t1.NAME

이 문에서 하위 쿼리(T1)는 NULL이 아니고 비어 있지 않은 "VALUE" 값을 사용하여 고유한 행을 추출합니다. 그런 다음 기본 쿼리(t)는 "ID" 및 "NAME" 필드에서 이 하위 쿼리와 조인되어 업데이트할 행을 식별합니다. 결과적으로 빈 'VALUE' 셀은 동일한 'NAME' 값을 가진 비어 있지 않은 행의 해당 값으로 채워집니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3