MySQL의 'SELECT * INTO OUTFILE' 명령은 한 번 사용되었습니다. 간단한 데이터 추출은 보안상의 이유로 제한되었습니다. 그러나 'LOAD DATA LOCAL INFILE' 명령은 계속 작동하므로 사용자는 해당 'SELECT INTO OUTFILE LOCAL' 옵션을 사용할 수 없는 이유를 궁금해하게 됩니다.
'LOAD DATA LOCAL INFILE'이 작동하는 이유는 무엇입니까?
'LOAD DATA LOCAL INFILE'을 사용하면 MySQL을 호스팅하는 서버의 로컬 파일에서 데이터를 가져올 수 있습니다. 해당 기능은 서버에만 국한되어 보안 문제가 없으므로 계속 사용할 수 있습니다.
'SELECT INTO OUTFILE LOCAL'을 선택하면 안 되는 이유는 무엇입니까?
'SELECT INTO OUTFILE'은 데이터를 서버 자체의 텍스트 파일로 내보내려고 합니다. 그러나 이 파일이 원격 대상용인 경우 보안 조치로 인해 이 작업이 방지됩니다. 서버 내에서 동작하는 'LOAD DATA INFILE'과 달리 'SELECT INTO OUTFILE'은 잠재적으로 서버에서 데이터를 추출해 외부 위치로 전송할 수 있어 보안 취약점이 발생할 수 있습니다.
대안 접근법
이 보안 위험을 완화하려면 원래 질문에 제공된 예에 표시된 대로 'mysql' 명령줄 도구를 사용할 수 있습니다. '>'를 사용하여 'SELECT' 쿼리의 출력을 파일로 리디렉션하면 서버 보안을 손상시키지 않고 데이터를 로컬 또는 원격 대상으로 효과적으로 전송할 수 있습니다.
MariaDB 기능
MySQL의 포크인 MariaDB도 유사한 보안 문제로 인해 'SELECT INTO OUTFILE' 명령을 제한합니다. 하지만 'LOAD DATA LOCAL INFILE' 명령을 지원하므로 로컬 서버 파일에서 데이터를 가져올 수 있습니다.
위 내용은 MySQL에서 \'SELECT * INTO OUTFILE LOCAL\'이 비활성화되어 있지만 \'LOAD DATA LOCAL INFILE\'은 계속 사용 가능한 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!