동일 테이블 형제의 데이터로 행 업데이트
다음과 유사한 구조로 테이블을 구상합니다. 이:
ID | 이름 | 값 |
---|---|---|
1 | 테스트 | VALUE1 |
2 | 테스트2 | VALUE2 |
1 | 테스트2 | NULL |
4 | 테스트 | NULL |
1 | 테스트3 | VALUE3 |
귀하의 작업은 NULL "VALUE" 셀을 동일한 "NAME"을 포함하는 다른 행의 데이터로 채우는 것입니다(즉, "Test" 및 "Test2"는 이전 항목의 값을 상속해야 합니다). 원하는 결과 상태:
ID | 이름 | 값 |
---|---|---|
1 | 테스트 | VALUE1 |
2 | 테스트2 | VALUE2 |
1 | 테스트2 | VALUE2 |
4 | 테스트 | VALUE1 |
1 | 테스트3 | VALUE3 |
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.NAMEUPDATE 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