mongoexport
이 문서는 mongoexport
의 100.10.0
버전에 대한 설명입니다.
Synopsis
mongoexport
MongoDB 인스턴스에 저장된 데이터의 JSON 또는 CSV 내보내기를 생성하는 데이터베이스 도구입니다.
mongo
shell이 아닌, 시스템 명령줄에서 mongoexport
를 실행합니다.
mongoexport
배포를 백업하기 위한 도구가 아닙니다. 백업 솔루션을 생성하려면 MongoDB 도구를 사용하여 자체 관리형 배포 백업 및 복원을 참조하세요.
참고
스토리지 비용을 절약하기 위해 오래된 데이터를 보관하려는 경우 MongoDB Atlas의 Online Archive를 고려해 보세요. Atlas Online Archive는 자주 액세스하지 않는 데이터를 관리형 S3 버킷에 자동으로 보관하여 비용 효율적인 데이터 계층화를 지원합니다.
MongoDB Database Tools를 사용하여 자체 호스팅 배포서버에서 MongoDB Atlas로 마이그레이션할 수 있습니다. MongoDB Atlas는 클라우드에서의 MongoDB 배포서버를 위한 완전 관리형 서비스입니다. 자세한 내용은 mongorestore로 시드 구성을 참조하세요.
MongoDB Atlas로 마이그레이션할 수 있는 모든 방법을 알아보려면 데이터 마이그레이션 또는 가져오기를 참조하세요.
구문
mongoexport
구문:
mongoexport --collection=<coll> <options> <connection-string>
내보내려면 collection
을 지정해야 합니다. output file
를 지정하지 않으면 mongoexport
가 표준 출력에 기록합니다(예: stdout).
MongoDB 인스턴스에 연결
포트 27017에서 실행 중인 로컬 MongoDB 인스턴스에 연결하려면 호스트 또는 포트를 지정할 필요가 없습니다.
예를 들어, 지정된 collection
을 포트 27017에서 실행 중인 로컬 MongoDB 인스턴스에서 지정된 output file
에 내보내려면 다음을 수행합니다.
mongoexport --collection=events --db=reporting --out=events.json
MongoDB 인스턴스의 호스트 및/또는 포트를 지정하려면 다음 두 가지 방법을 사용할 수 있습니다:
--uri connection string
에 호스트 이름과 포트를 지정합니다.mongoexport --uri="mongodb://mongodb0.example.com:27017/reporting" --collection=events --out=events.json [additional options] --uri connection string
을 사용하는 경우 데이터베이스를 string 의 일부로 지정할 수 있습니다.mongoexport --host="mongodb0.example.com:27017" --collection=events --db=reporting --out=events.json [additional options] --host
및--port
에 호스트 이름과 포트를 지정합니다.mongoexport --host="mongodb0.example.com" --port=27017 --collection=events --db=reporting --out=events.json [additional options]
사용 가능한 옵션에 대한 자세한 내용은 옵션을 참조하세요.
복제본 세트에 연결
참고
mongoexport
는 데이터 백업용 도구가 아닙니다. 복제본 세트를 백업하려면 MongoDB 도구를 사용하여 자체 관리 배포 백업 및 복원을 참조하세요.
복제본 세트에 연결하여 데이터를 내보내려면 다음 두 가지 방법을 사용할 수 있습니다:
--uri connection string
에 복제본 세트 이름과 멤버를 지정합니다.mongoexport --uri="mongodb://mongodb0.example.com:27017,mongodb1.example.com:27017,mongodb2.example.com:27017/reporting?replicaSet=myReplicaSetName" --collection=events --out=events.json [additional options] --uri connection string
을 사용하는 경우 데이터베이스를 string 의 일부로 지정할 수 있습니다.--host
에 복제본 세트 이름과 멤버를 지정합니다.mongoexport --host="myReplicaSetName/mongodb0.example.com:27017,mongodb1.example.com:27017,mongodb2.example.com" --collection=events --db=reporting --out=events.json [additional options]
기본적으로 mongoexport
는 복제본 세트의 프라이머리에서 읽습니다. 기본값을 재정의하려면 읽기 설정을 지정하면 됩니다.
읽기 설정을 지정할 수 있습니다.
--uri connection string
mongoexport --uri="mongodb://mongodb0.example.com:27017,mongodb1.example.com:27017,mongodb2.example.com:27017/reporting?replicaSet=myReplicaSetName&readPreference=secondary" --collection=events --out=events.json [additional options] 읽기 설정 태그를 지정하는 경우
readPreferenceTags
옵션을 포함합니다.mongoexport --uri="mongodb://mongodb0.example.com:27017,mongodb1.example.com:27017,mongodb2.example.com:27017/reporting?replicaSet=myReplicaSetName&readPreference=secondary&readPreferenceTags=region:east" --collection=events --out=events.json [additional options] --uri connection string
을 사용하는 경우 데이터베이스를 string 의 일부로 지정할 수 있습니다.--readPreference
명령줄 옵션을 사용하여 읽기 설정을 지정할 수 있습니다. 명령줄 옵션은 읽기 설정 모드만 지정하는 경우 string 을 사용합니다.mongoexport --host="myReplicaSetName/mongodb0.example.com:27017,mongodb1.example.com:27017,mongodb2.example.com:27017" --readPreference=secondary --collection=events --db=reporting --out=events.json [additional options] 또는 명령줄 옵션에서 따옴표로 묶인 문서
'{ mode: <mode>, tagSets: [ <tag1>, ... ], maxStalenessSeconds:<num>}'
를 사용하여 모드, 선택적 읽기 설정 태그 세트 및 선택적 maxStalenessSeconds를 지정할 수 있습니다.mongoexport --host="myReplicaSetName/mongodb0.example.com:27017,mongodb1.example.com:27017,mongodb2.example.com:27017" --readPreference='{mode: "secondary", tagSets: [ { "region": "east" } ]}' --collection=events --db=reporting --out=events.json [additional options]
사용 가능한 옵션에 대한 자세한 내용은 옵션을 참조하세요.
샤딩된 클러스터에 연결
참고
mongoexport
데이터를 백업하기 위한 도구가 아닙니다. 샤딩된 클러스터를 백업하려면 자체 관리형 샤딩된 클러스터 백업 및 복원을 참조하세요.
샤딩된 클러스터에 연결하여 데이터를 내보내려면 다음 두 가지 방법을 사용할 수 있습니다:
에 인스턴스의 호스트
mongos
이름을--uri connection string
지정합니다.mongoexport --uri="mongodb://mongos0.example.com:27017/reporting" --collection=events --out=events.json [additional options] --uri connection string
을 사용하는 경우 데이터베이스를 string 의 일부로 지정할 수 있습니다.에 인스턴스의 호스트
mongos
이름 및--host
포트를 지정합니다.mongoexport --host="mongos0.example.com:27017" --collection=events --db=reporting --out=events.json[additional options]
기본적으로 mongoexport
은 샤드 복제본 세트의 프라이머리에서 읽습니다. 기본값을 재정의하려면 읽기 설정을 지정하면 됩니다.
읽기 설정을 지정할 수 있습니다.
--uri connection string
mongoexport --uri="mongodb://mongos0.example.com:27017/reporting?readPreference=secondary" --collection=events --out=events.json [additional options] 읽기 설정 태그를 지정하는 경우
readPreferenceTags
옵션을 포함합니다.mongoexport --uri="mongodb://mongos0.example.com:27017/reporting?readPreference=secondary&readPreferenceTags=region:east" --collection=events --out=events.json [additional options] --uri connection string
을 사용하는 경우 데이터베이스를 string 의 일부로 지정할 수 있습니다.--readPreference
명령줄 옵션을 사용하여 읽기 설정을 지정할 수 있습니다. 명령줄 옵션은 읽기 설정 모드만 지정하는 경우 string 을 사용합니다.mongoexport --host="mongos0.example.com:27017" --readPreference=secondary --collection=events --db=reporting --out=events.json [additional options] 또는 명령줄 옵션에서 따옴표로 묶인 문서
'{ mode: <mode>, tagSets: [ <tag1>, ... ], maxStalenessSeconds:<num>}'
를 사용하여 모드, 선택적 읽기 설정 태그 세트 및 선택적 maxStalenessSeconds를 지정할 수 있습니다.mongoexport --host="mongos0.example.com:27017" --readPreference='{mode: "secondary", tagSets: [ { "region": "east" } ]}' --collection=events --db=reporting --out=events.json [additional options]
옵션
--quiet
출력량을 제한하려고 시도하는 자동 모드에서
mongoexport
를 실행합니다.이 옵션은 다음과 같은 활동을 억제합니다.
데이터베이스 명령에서 출력
복제 활동
연결 수락 및 종료 이벤트
오류 메시지를 포함한 모든 로그(옵션 구문 분석 시 발생하는 로그 제외)
--config=<filename>
버전 100.3.0의 새로운 기능.
다음 옵션에 대한 중요한 값을 포함하는 YAML 구성 파일의 전체 경로를
mongoexport
에 지정합니다.비밀번호 프롬프트를 통해 비밀번호를 지정하는 것 외에
mongoexport
에 비밀번호를 지정하는 권장 방법입니다.구성 파일은 다음과 같은 형식을 취합니다:
password: <password> uri: mongodb://mongodb0.example.com:27017 sslPEMKeyPassword: <password> password:
필드에 암호를 지정하고uri:
필드에 충돌하는 암호가 포함된 연결 문자열을 제공하면 오류가 발생합니다.적절한 파일 시스템 권한으로 이 파일을 보호해야 합니다.
참고
--config
로 구성 파일을 지정하고--password
,--uri
또는--sslPEMKeyPassword
옵션을mongoexport
에 사용하는 경우 각 명령줄 옵션은 구성 파일의 해당 옵션을 재정의합니다.
--uri=<connectionString>
따옴표로 묶인 MongoDB 배포의 확인 가능한 URI 연결 문자열을 지정합니다.
--uri="mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]" mongoexport
의100.0
버전부터는--uri
옵션을 사용하지 않고 대신 위치 매개변수로 연결 문자열을 제공할 수도 있습니다.mongoexport mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]] 연결 문자열은
mongodb://
또는mongodb+srv://
중 하나로 시작하기만 하면 명령줄의 어느 지점에서나 위치 매개변수로 지정할 수 있습니다. 예시:mongoexport --username joe --password secret1 mongodb://mongodb0.example.com:27017 --ssl 연결 문자열은 하나만 제공할 수 있습니다.
--uri
옵션을 사용하든 위치 인수로 사용하든 둘 이상을 포함하려고 하면 오류가 발생합니다.연결 문자열의 구성 요소에 대한 자세한 내용은 연결 문자열 URI 형식 문서를 참조하세요.
참고
connection string
의 일부 구성요소는--username
및--password
와 같은 자체 명시적 명령줄 옵션을 사용하여 지정할 수도 있습니다. 명시적 옵션을 사용하면서 연결 문자열을 제공하고 충돌하는 정보를 지정하면 오류가 발생합니다.참고
mongoexport
Ubuntu 18.04를 사용하는 경우--uri
옵션과 함께 SRV 연결 문자열(mongodb+srv://
형식)을 사용하면cannot unmarshal DNS
오류 메시지가 나타날 수 있습니다. 이 경우 다음 옵션 중 하나를 대신 사용합니다.비SRV 연결 문자열이 있는
--uri
옵션(mongodb://
형식)--host
옵션을 사용하여 직접 연결할 호스트를 지정하세요.
--host=<hostname><:port>, -h=<hostname><:port>
기본값: localhost:27017
MongoDB deployment의 확인 가능한 호스트 이름을 지정합니다. 기본적으로
mongoexport
는 포트 번호27017
의 로컬 호스트에서 실행되는 MongoDB 인스턴스에 연결을 시도합니다.복제본 세트에 연결하려면 다음과 같이
replSetName
과 세트 멤버의 시드 목록을 지정합니다.--host=<replSetName>/<hostname1><:port>,<hostname2><:port>,<...> 복제본 설정 목록 형식을 지정할 때
mongoexport
는 항상 프라이머리에 연결합니다.또한 해당 멤버의 호스트와 포트만 지정하여 복제본 세트의 단일 멤버에 연결할 수 있습니다.
--host=<hostname1><:port> IPv6을 사용하고
<address>:<port>
형식을 사용하는 경우 주소 및 포트 조합의 일부를 대괄호로 묶어야 합니다 (예:[<address>]
).또는
URI connection string
에 호스트 이름을 직접 지정할 수도 있습니다.--host
를 사용하면서 연결 문자열을 제공하고 충돌하는 정보를 지정하면 오류가 발생합니다.
--port=<port>
기본값: 27017
MongoDB 인스턴스가 클라이언트 연결 수신을 대기하는 TCP 포트를 지정합니다.
또는
URI connection string
에 포트를 직접 지정할 수도 있습니다. 연결 문자열을 제공하면서--port
를 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.
--ssl
TLS/SSL 지원이 활성화된
mongod
또는mongos
에 연결할 수 있습니다.또는
URI connection string
에서 직접 TLS/SSL 지원을 구성할 수도 있습니다. 연결 문자열을 제공하면서--ssl
을 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.TLS/SSL 및 MongoDB에 대한 자세한 내용은 TLS/SSL용 mongod 및 mongos 구성 및 클라이언트용 TLS/SSL 구성을 참조하세요.
--sslCAFile=<filename>
인증 기관의 루트 인증서 체인이 포함된
.pem
파일을 지정합니다. 상대 경로 또는 절대 경로를 사용하여.pem
파일의 이름을 지정합니다.또는
URI connection string
에 직접.pem
파일을 지정할 수도 있습니다. 연결 문자열을 제공하면서--sslCAFile
을 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.TLS/SSL 및 MongoDB에 대한 자세한 내용은 TLS/SSL용 mongod 및 mongos 구성 및 클라이언트용 TLS/SSL 구성을 참조하세요.
--sslPEMKeyFile=<filename>
TLS/SSL 인증서와 키가 모두 포함되어 있는
.pem
파일을 지정합니다. 상대 경로 또는 절대 경로를 사용해.pem
파일의 이름을 지정합니다.이 옵션은 옵션을 사용하여
allowConnectionsWithoutCertificates
없이--ssl
{ 가mongos
활성화된mongod
CAFile
또는 에 연결할 때 필요합니다또는
URI connection string
에 직접.pem
파일을 지정할 수도 있습니다. 연결 문자열을 제공하면서--sslPEMKeyFile
을 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.TLS/SSL 및 MongoDB에 대한 자세한 내용은 TLS/SSL용 mongod 및 mongos 구성 및 클라이언트용 TLS/SSL 구성을 참조하세요.
--sslPEMKeyPassword=<value>
인증서-키 파일 해독을 위한 비밀번호를 지정합니다(예:
--sslPEMKeyFile
). 인증서 키 파일이 암호화된 경우에만--sslPEMKeyPassword
옵션을 사용합니다. 모든 경우에mongoexport
는 모든 로깅 및 보고 출력에서 비밀번호를 삭제합니다.PEM 파일의 개인 키가 암호화되어 있고
--sslPEMKeyPassword
옵션을 지정하지 않은 경우mongoexport
에 패스프레이즈(passphrase)를 입력하라는 메시지가 표시됩니다. TLS/SSL 인증서 패스프레이즈를 참조하세요.또는
URI connection string
에 비밀번호를 직접 지정할 수도 있습니다. 연결 문자열을 제공하면서--sslPEMKeyPassword
를 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.TLS/SSL 및 MongoDB에 대한 자세한 내용은 TLS/SSL용 mongod 및 mongos 구성 및 클라이언트용 TLS/SSL 구성을 참조하세요.
경고
일부 시스템에서는
--sslPEMKeyPassword
옵션을 사용해 직접 제공된 비밀번호가 다른 사용자가 호출할 수 있는ps
와 같은 시스템 상태 프로그램에 표시될 수 있습니다. 대신--config
옵션을 사용하여 비밀번호가 포함된 구성 파일을 지정하는 것이 좋습니다.
--sslCRLFile=<filename>
인증서 해지 목록이 포함된
.pem
파일을 지정합니다. 상대 경로 또는 절대 경로를.pem
파일의 이름을 지정합니다.TLS/SSL 및 MongoDB에 대한 자세한 내용은 TLS/SSL용 mongod 및 mongos 구성 및 클라이언트용 TLS/SSL 구성을 참조하세요.
--sslAllowInvalidCertificates
서버 인증서에 대한 유효성 검사를 우회하고 유효하지 않은 인증서의 사용을 허용합니다.
allowInvalidCertificates
설정을 사용할 때 MongoDB는 유효하지 않은 인증서 사용에 대한 경고를 기록합니다.경고
또는
URI connection string
에서 인증서 유효성 검사를 비활성화할 수도 있습니다. 연결 문자열을 제공하면서--sslAllowInvalidCertificates
를 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.TLS/SSL 및 MongoDB에 대한 자세한 내용은 TLS/SSL용 mongod 및 mongos 구성 및 클라이언트용 TLS/SSL 구성을 참조하세요.
--sslAllowInvalidHostnames
TLS/SSL 인증서의 호스트 이름 유효성 검사를 비활성화합니다. 인증서의 호스트 이름이 지정된 호스트 이름과 일치하지 않더라도
mongoexport
가 MongoDB 인스턴스에 연결할 수 있도록 허용합니다.또는
URI connection string
에서 호스트 이름 유효성 검사를 비활성화할 수도 있습니다.--sslAllowInvalidHostnames
를 사용하면서 연결 문자열을 제공하고 충돌하는 정보를 지정하면 오류가 발생합니다.TLS/SSL 및 MongoDB에 대한 자세한 내용은 TLS/SSL용 mongod 및 mongos 구성 및 클라이언트용 TLS/SSL 구성을 참조하세요.
--username=<username>, -u=<username>
인증을 사용하는 MongoDB 데이터베이스에 인증하는 데 사용할 사용자 이름을 지정합니다.
--password
및--authenticationDatabase
옵션과 함께 사용합니다.또는
URI connection string
에 직접 사용자 이름을 지정할 수도 있습니다. 연결 문자열을 제공하면서--username
을 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.MONGODB-AWS
authentication mechanism
을 사용하여 MongoDB Atlas 클러스터에 연결하는 경우 다음에 AWS 액세스 키 ID를 지정할 수 있습니다.이 필드,
AWS_ACCESS_KEY_ID
환경 변수.
각각의 예는 AWS IAM 자격 증명을 사용하여 MongoDB Atlas Cluster에 연결하기를 참조하세요.
--password=<password>, -p=<password>
인증을 사용하는 MongoDB database에 인증하는 데 사용할 비밀번호를 지정합니다.
--username
및--authenticationDatabase
옵션과 함께 사용합니다.사용자에게 비밀번호를 묻는 메시지를 표시하려면
--password
없이--username
옵션을 전달하거나--password ""
에서와 같이 빈 문자열을--password
값으로 지정합니다.또는
URI connection string
에 비밀번호를 직접 지정할 수도 있습니다. 연결 문자열을 제공하면서--password
를 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.MONGODB-AWS
authentication mechanism
을 사용하여 MongoDB Atlas 클러스터에 연결하는 경우 다음에서 AWS 시크릿 액세스 키를 지정할 수 있습니다.이 필드,
AWS_SECRET_ACCESS_KEY
환경 변수.
각각의 예는 AWS IAM 자격 증명을 사용하여 MongoDB Atlas Cluster에 연결하기를 참조하세요.
경고
일부 시스템에서는
--password
옵션을 사용해 직접 제공된 비밀번호가 다른 사용자가 호출할 수 있는ps
와 같은 시스템 상태 프로그램에 표시될 수 있습니다. 대신 다음을 고려합니다.--password
옵션을 생략하여 대화형 암호 프롬프트를 받거나, 또는--config
옵션을 사용하여 비밀번호가 포함된 구성 파일을 지정합니다.
--awsSessionToken=<AWS Session Token>
MONGODB-AWS
authentication mechanism
를 사용하여 MongoDB Atlas 클러스터에 연결하고 AWS 액세스 키 ID 및 시크릿 액세스 키 외에 세션 토큰을 사용하는 경우, 다음에서 AWS 세션 토큰을 지정할 수 있습니다.이 필드,
connection string
에 대한AWS_SESSION_TOKEN
authMechanismProperties
매개 변수, 또는AWS_SESSION_TOKEN
환경 변수.
각각의 예는 AWS IAM 자격 증명을 사용하여 MongoDB Atlas Cluster에 연결하기를 참조하세요.
MONGODB-AWS
authentication mechanism
을 사용할 때만 유효합니다.
--authenticationDatabase=<dbname>
지정한
--username
이 생성된 인증 데이터베이스를 지정합니다. 인증 데이터베이스를 참조하세요.인증 데이터베이스를 지정하지 않으면
mongoexport
는 내보내도록 지정된 데이터베이스가 사용자의 자격 증명을 보유하고 있다고 가정합니다.GSSAPI(Kerberos), PLAIN(LDAP SASL) 또는
MONGODB-AWS
authentication mechanisms
를 사용하는 경우--authenticationDatabase
를$external
로 설정해야 합니다.또는
URI connection string
에서 직접 인증 데이터베이스를 지정할 수도 있습니다. 연결 문자열을 제공하면서--authenticationDatabase
를 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.
--authenticationMechanism=<name>
기본값: SCRAM-SHA-1
mongoexport
인스턴스가mongod
또는mongos
를 인증하는 데 사용하는 인증 메커니즘을 지정합니다.버전 100.1.0 변경 사항: 버전
100.1.0
부터mongoexport
는 MongoDB Atlas 클러스터에 연결할 때MONGODB-AWS
인증 메커니즘에 대한 지원을 추가합니다.값설명RFC 5802 SHA-1 해시 함수를 사용하는 표준 Salted Challenge Response 인증 메커니즘.RFC 7677 표준 SHA-256 해시 함수를 사용하는 솔티드 챌린지 응답 인증 메커니즘.
featureCompatibilityVersion이
4.0
으로 설정되어야 합니다.MongoDB TLS/SSL 인증서 인증.MONGODB-AWS
MongoDB Atlas 클러스터 연결에 사용하기 위한 AWS IAM 자격 증명을 사용하는 외부 인증입니다. AWS IAM 자격 증명을 사용하여 MongoDB Atlas 클러스터에 연결하기를 참조하세요.
버전 100.1.0의 새로운 기능.
GSSAPI (Kerberos)Kerberos를 사용한 외부 인증. 이 메커니즘은 MongoDB Enterprise에서만 사용할 수 있습니다.PLAIN (LDAP SASL)LDAP를 사용한 외부 인증.PLAIN
을 사용해 데이터베이스 내 사용자를 인증할 수도 있습니다.PLAIN
은 비밀번호를 일반 텍스트로 전송합니다. 이 메커니즘은 MongoDB Enterprise에서만 사용할 수 있습니다.또는
URI connection string
에서 직접 인증 메커니즘을 지정할 수도 있습니다. 연결 문자열을 제공하면서--authenticationMechanism
를 사용하고 상충하는 정보를 지정하면 오류가 발생합니다.
--gssapiServiceName=<serviceName>
GSSAPI/Kerberos를 사용하여 서비스 이름을 지정합니다. 서비스가 기본값 이름인
mongodb
를 사용하지 않는 경우에만 필요합니다.이 옵션은 MongoDB Enterprise에서만 사용할 수 있습니다.
--gssapiHostName=<hostname>
GSSAPI/Kerberos를 사용하여 서비스의 호스트 이름을 지정합니다. 시스템의 호스트 이름이 DNS에서 확인한 호스트 이름과 일치하지 않는 경우에만 필요합니다.
이 옵션은 MongoDB Enterprise에서만 사용할 수 있습니다.
--db=<database>, -d=<database>
mongoexport
을(를) 실행할 데이터베이스의 이름을 지정합니다.또는
URI connection string
에 직접 데이터베이스를 지정할 수도 있습니다.--db
를 사용하는 동안 연결 문자열을 제공하고 충돌하는 정보를 지정하면 오류가 발생합니다.
--fields=<field1[,field2]>, -f=<field1[,field2]>
내보내기에 포함할 필드를 지정합니다. 여러 필드를 지정하려면 쉼표로 구분된 필드 목록을 사용하세요.
필드 이름에 공백이 포함된 경우 따옴표를 사용하여 필드 목록을 묶습니다. 예를 들어
phone
과user number
두 필드를 내보내려면--fields "phone,user number"
를 지정합니다.csv
출력 형식의 경우mongoexport
에는 지정된 필드만 포함되며, 지정된 필드는 하위 문서 내의 필드일 수 있습니다.JSON 출력 형식의 경우
mongoexport
에는 지정된 필드 와_id
필드만 포함되며, 지정된 필드가 하위 문서 내의 필드인 경우mongoexport
에는 다음과 같은 하위 문서가 포함됩니다. 문서 내의 지정된 필드뿐만 아니라 모든 필드.참조: 샘플 사용을 위해
--fields
옵션을 사용하여 CSV 형식으로 데이터 내보내기 .
--fieldFile=<filename>
--fields
의 대안입니다.--fieldFile
옵션을 사용하면 내보내기에 포함 할 필드를 파일에 지정할 수 있으며 값이--type
있는 옵션 에서만 유효합니다csv
. 파일에는 한 줄에 하나의 필드만 있어야 하며 줄은 LF 문자(0x0A
)로 끝나야 합니다.mongoexport
지정된 필드만 포함합니다. 지정된 필드는 하위 문서 내의 필드일 수 있습니다.샘플 사용법 은 파일을 사용하여 CSV 형식으로 내보낼 필드 지정을 참조하세요.
--query=<JSON>, -q=<JSON>
내보내기에서 일치하는 문서를 반환하기 위해 쿼리를 JSON 문서(따옴표로 묶음)로 제공합니다.
쿼리 문서가 셸 환경과 상호 작용하지 않도록 하려면 쿼리 문서를 작은따옴표(
'{ ... }'
)로 묶어야 합니다.쿼리는 반드시 필드 이름과 연산자를 따옴표로 묶는 것을 포함하여 확장 JSON v2 형식(완화 또는 표준/엄격 모드)이어야 합니다.
예를 들어
test
데이터베이스에records
컬렉션이 다음 문서와 함께 있다고 가정합니다.{ "_id" : ObjectId("51f0188846a64a1ed98fde7c"), "a" : 1, "date" : ISODate("1960-05-01T00:00:00Z") } { "_id" : ObjectId("520e61b0c6646578e3661b59"), "a" : 1, "b" : 2, "date" : ISODate("1970-05-01T00:00:00Z") } { "_id" : ObjectId("520e642bb7fa4ea22d6b1871"), "a" : 2, "b" : 3, "c" : 5, "date" : ISODate("2010-05-01T00:00:00Z") } { "_id" : ObjectId("520e6431b7fa4ea22d6b1872"), "a" : 3, "b" : 3, "c" : 6, "date" : ISODate("2015-05-02T00:00:00Z") } { "_id" : ObjectId("520e6445b7fa4ea22d6b1873"), "a" : 5, "b" : 6, "c" : 8, "date" : ISODate("2018-03-01T00:00:00Z") } { "_id" : ObjectId("5cd0de910dbce4346295ae28"), "a" : 15, "b" : 5, "date" : ISODate("2015-03-01T00:00:00Z") } 다음
mongoexport
는-q
옵션을 사용하여a
필드가 ($gte
)3
보다 크거나 같고date
필드가 ($lt
)ISODate("2016-01-01T00:00:00Z")
(이는 날짜({ "$date": "YYYY-MM-DDTHH:mm:ss.mmm\<offset\>"}
)에 대해 확장 JSON v2 형식(완화 모드)을 사용하여 지정됨)보다 작은 문서만 내보냅니다.mongoexport -d=test -c=records -q='{ "a": { "$gte": 3 }, "date": { "$lt": { "$date": "2016-01-01T00:00:00.000Z" } } }' --out=exportdir/myRecords.json 결과 파일에는 다음 문서가 포함됩니다:
{"_id":{"$oid":"520e6431b7fa4ea22d6b1872"},"a":3.0,"b":3.0,"c":6.0,"date":{"$date":"2015-05-02T00:00:00Z"}} {"_id":{"$oid":"5cd0de910dbce4346295ae28"},"a":15.0,"b":5.0,"date":{"$date":"2015-03-01T00:00:00Z"}} --sort
옵션을 사용하여 결과를mongoexport
로 정렬할 수 있습니다.
--queryFile=<filename>
--query
의 대안입니다.--queryFile
옵션을 사용하면 파일에서 쿼리를 확장 JSON v2 형식으로 지정할 수 있습니다.
--type=<string>
Default: json
내보낼 파일 형식을 지정합니다. CSV 형식의 경우
csv
를 지정하고 JSON 형식의 경우json
를 지정합니다.csv
을 지정하는 경우--fields
또는--fieldFile
옵션도 사용하여 컬렉션에서 내보낼 필드를 선언해야 합니다.
--out=<file>, -o=<file>
내보내기를 기록할 파일을 지정합니다. 파일 이름을 지정하지 않으면
mongoexport
이(가) 표준 출력에 데이터를 씁니다(예:stdout
).
--jsonFormat=<canonical|relaxed>
기본값: relaxed
MongoDB 확장 JSON(v2) 형식의 표준 또는 완화 모드를 사용하도록 출력을 수정합니다.
표준 모드와 완화 모드의 차이점은 MongoDB 확장 JSON(v2)을 참조하세요.
--jsonArray
mongoexport
의 출력을 수정하여 내보내기의 전체 내용을 단일 JSON 배열로 작성합니다.mongoexport
기본적으로 는 JSON document 모든 문서에 대해 하나의 MongoDB 를 사용하여 데이터를 씁니다.
--noHeaderLine
기본적으로
mongoexport
에는 내보낸 필드 이름이 CSV 출력의 첫 번째 줄에 포함됩니다.--noHeaderLine
는 필드 이름 목록 없이 데이터를 내보내도록mongoexport
에 지시합니다. 는 값이--noHeaderLine
--type
인 옵션 에서만 유효합니다 .csv
샘플 사용법 은 CSV 출력에서 필드 이름 제외를 참조하세요.
--readPreference=<string|document>
기본값:
primary
mongoexport
에 대한 읽기 설정 을 지정합니다.--readPreference
옵션은 다음을 사용할 수 있습니다.읽기 설정 모드만 지정하는 경우 문자열입니다:
--readPreference=secondary 따옴표로 묶인 문서를 통해 모드, 선택적 읽기 설정 태그 세트 및 선택적 maxStalenessSeconds를 지정할 수 있습니다.
--readPreference='{mode: "secondary", tagSets: [ { "region": "east" } ], maxStalenessSeconds: 120}' maxStalenessSeconds를 지정하는 경우 값은 90 이상이어야 합니다.
mongoexport
기본값은primary
읽기 설정입니다.읽기 설정이
--uri connection string
에도 포함되어 있으면 명령줄--readPreference
이 URI string 에 지정된 읽기 설정을 재정의합니다.
--skip=<number>
--skip
를 사용하여mongoexport
가 문서 내보내기를 시작하는 위치를 제어합니다. 기본 작업에 대한 자세한 내용은skip()
를 참조하세요.
--limit=<number>
내보내기에 포함할 최대 문서 수를 지정합니다. 기본 작업에 대한 자세한 내용은
limit()
를 참조하세요.
--sort=<JSON>
내보낸 결과의 순서를 지정합니다. 정렬 작업을 지원할 수 있는 인덱스가 존재하지 않는 경우 결과는 32메가바이트 미만이어야 합니다.
--sort
를--skip
및--limit
와 함께 사용하여 내보내는 문서 수를 제한합니다.mongoexport -d=test -c=records --sort='{a: 1}' --limit=100 --out=export.0.json mongoexport -d=test -c=records --sort='{a: 1}' --limit=100 --skip=100 --out=export.1.json mongoexport -d=test -c=records --sort='{a: 1}' --limit=100 --skip=200 --out=export.2.json 기본 작업에 대한 자세한 내용은
sort()
를 참조하세요.