집 >데이터 베이스 >MySQL 튜토리얼 >CSV 데이터를 MySQL에 로드할 때 올바른 NULL 값 처리를 어떻게 보장할 수 있습니까?
MySQL: CSV 데이터 로드 중 NULL 값 처리
누락되거나 비어 있는 필드가 포함될 수 있는 CSV 데이터를 처리할 때 다음이 중요합니다. 데이터 로딩 프로세스 중에 MySQL이 이러한 null 값을 처리하는 방법을 설명합니다. 이 기사에서는 CSV 파일의 데이터를 MySQL 테이블로 로드하려고 시도하는 동안 발생하는 문제와 이를 해결하여 정확한 NULL 값 처리를 보장하는 방법을 살펴보겠습니다.
제공된 시나리오에서 CSV 파일에는 잠재적으로 비어 있는 필드가 있는 숫자 값입니다. 그러나 MySQL LOAD 명령을 사용하여 데이터를 로드할 때 행 끝에 명시적으로 정의되지 않은 빈 필드가 NULL 대신 0으로 로드되었습니다. 이러한 잘못된 동작으로 인해 null 값과 0 값을 구별하는 데 문제가 발생했습니다.
이 문제를 해결하는 열쇠는 null 값을 올바르게 처리하도록 데이터 로드 프로세스를 사용자 정의하는 데 있습니다. 해결 방법은 빈 필드를 지역 변수로 읽어온 다음 지역 변수에 빈 문자열이 있을 때 테이블의 해당 필드를 명시적으로 NULL로 설정하는 것입니다.
다음은 이 솔루션을 통합하는 수정된 코드의 예입니다.
LOAD DATA INFILE '/tmp/testdata.txt' INTO TABLE moo FIELDS TERMINATED BY "," LINES TERMINATED BY "\n" (one, two, three, @vfour, five) SET four = NULLIF(@vfour,'') ;
이 코드에서 네 번째 필드는 로컬 변수 @vfour로 읽혀집니다. @vfour에 빈 문자열이 포함되어 있으면 테이블의 해당 4개 필드가 NULL로 설정됩니다. 이 접근 방식을 사용하면 빈 필드가 NULL 값으로 올바르게 해석되어 0 값과의 혼동을 방지할 수 있습니다.
또는 여러 필드에 Null 값이 포함될 수 있는 경우 해당 값을 모두 변수로 읽고 여러 SET 문을 사용하여 처리할 수 있습니다. 각 필드는 명시적으로:
LOAD DATA INFILE '/tmp/testdata.txt' INTO TABLE moo FIELDS TERMINATED BY "," LINES TERMINATED BY "\n" (@vone, @vtwo, @vthree, @vfour, @vfive) SET one = NULLIF(@vone,''), two = NULLIF(@vtwo,''), three = NULLIF(@vthree,''), four = NULLIF(@vfour,'') ;
이러한 솔루션을 구현하면 MySQL에서 CSV 데이터를 로드하는 동안 null 값을 처리하는 문제를 효과적으로 해결할 수 있습니다. 이렇게 하면 빈 필드가 NULL로 올바르게 저장되므로 데이터 분석 및 처리에서 null 값과 0 값을 효과적으로 구분할 수 있습니다.
위 내용은 CSV 데이터를 MySQL에 로드할 때 올바른 NULL 값 처리를 어떻게 보장할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!