> 데이터 베이스 > MySQL 튜토리얼 > LOAD DATA INFILE을 사용하여 CSV에서 MySQL로 0이 아닌 NULL 값을 로드하는 방법은 무엇입니까?

LOAD DATA INFILE을 사용하여 CSV에서 MySQL로 0이 아닌 NULL 값을 로드하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-12-22 07:28:09
원래의
729명이 탐색했습니다.

How to Load NULL Values, Not Zeros, from a CSV into MySQL using LOAD DATA INFILE?

MySQL: CSV 데이터에서 NULL 값 로드

문제:

빈 필드가 있는 CSV 파일에서 데이터를 로드하는 경우 LOAD DATA INFILE 명령을 사용하여 MySQL 테이블에 추가하면 MySQL은 NULL 대신 빈 필드에 0을 할당합니다. 열이 NULL 기본값으로 정의되었습니다.

해결책:

빈 필드에 대한 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,'')
;
로그인 후 복사

설명:

  • LOAD DATA INFILE 문은 CSV 파일의 데이터를 moo 테이블로 읽어옵니다.
  • FIELDS 절은 CSV 파일의 필드와 해당 열 이름을 정의합니다.
  • 네 번째 필드(@vfour)는 네 개의 열로 직접 읽히지 않고 지역 변수로 읽혀집니다.
  • SET 문은 @vfour 변수가 비어 있는지('') 확인합니다. NULLIF 함수를 사용합니다.
  • @vfour가 비어 있으면 4개 열이 NULL로 설정됩니다. 그렇지 않으면 원래 값을 유지합니다.

추가 참고 사항:

모든 필드가 비어 있을 수 있는 경우에는 모두 로컬 변수로 읽고 여러 필드를 사용합니다. NULL 값을 조건부로 할당하는 SET 문입니다.

위 내용은 LOAD DATA INFILE을 사용하여 CSV에서 MySQL로 0이 아닌 NULL 값을 로드하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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