Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

SSMS - mdf 파일을 Attach 시킬 때 Operating system error 5: "5(Access is denied.)" 에러

예를 들어, mdf/ldf 파일에 대해 "Microsoft SQL Server Management Studio" 도구로 "데이터베이스" 항목을 우클릭해 "연결(Attach)..." 메뉴를 선택, "데이터베이스 연결(Attach Databases)" 창에서 mdf 파일을 선택 후 "확인" 버튼을 눌렀을 때 다음과 같은 오류 창이 나타날 수 있습니다.

ssms_db_attach_1.png

데이터베이스를 연결하는 동안 오류가 발생했습니다. 자세한 내용을 보려면 메시지 열의 하이퍼링크를 클릭하십시오.

An error occurred when attaching the database(s).  Click the hyperlink in the Message column for details.

일단 "확인(OK)" 버튼을 누른 후, "연결할 데이터베이스(Databases to attch)" 리스트 박스의 칼럼 중 "메시지(Message)"를 보면 링크가 있을 텐데,

ssms_db_attach_2.png

그걸 누르면 다음과 같은 메시지를 볼 수 있습니다.

서버 'TESTPC\SQLEXPRESS'에 대한 데이터베이스 연결이(가) 실패했습니다.  (Microsoft.SqlServer.Smo)

...[생략]...

Transact-SQL 문 또는 일괄 처리를 실행하는 동안 예외가 발생했습니다. (Microsoft.SqlServer.ConnectionInfo)

물리적 파일 "D:\db\TestDB.mdf"을(를) 열 수 없습니다. 운영 체제 오류 5: "5(액세스가 거부되었습니다.)".
CREATE DATABASE가 실패했습니다. 나열된 일부 파일 이름을 만들 수 없습니다. 관련 오류를 확인하십시오. (Microsoft SQL Server, 오류: 5120)

Attach database failed for Server 'TESTPC\SQLEXPRESS'.  (Microsoft.SqlServer.Smo)

...[생략]...

An exception occurred while executing a Transact-SQL statement or batch. (Microsoft.SqlServer.ConnectionInfo)

Unable to open the physical file "C:\temp\TestDB.mdf". Operating system error 5: "5(Access is denied.)".
CREATE DATABASE failed. Some file names listed could not be created. Check related errors. (Microsoft SQL Server, Error: 5120)

주요 원인은 "Access is denied"인데요, 즉, mdf 파일을 접근하는데 실패했다는 것입니다. 해결 방법은 간단하겠죠? ^^ "Microsoft SQL Server Management Studio" 응용 프로그램을 관리자 권한으로 실행시키면 됩니다. ^^

주의할 것은, 이때 "관리자 권한"과 함께 SQL 로그인 인증을 반드시 "Windows 인증"으로 해야 합니다. 만약 "SQL Server 인증"으로 로그인하면 여전히 Access is denied 오류가 발생합니다. 부득이 "SQL Server 인증"으로 해야 한다면, mdf와 ldf 파일에 대해 보안 설정으로 들어가,

ssms_db_attach_3.png

위와 같이 "NT Service\MSSQL$SQLEXPRESS" 계정을 Full Control 권한으로 추가해 주면 됩니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 2/27/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  69  70  [71]  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12196정성태3/17/202017211오류 유형: 608. The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
12195정성태3/16/202019930.NET Framework: 902. C# - 프로세스의 모든 핸들을 열람 - 세 번째 이야기
12194정성태3/16/202022544오류 유형: 607. PostgreSQL - Npgsql.NpgsqlException: sorry, too many clients already
12193정성태3/16/202019624개발 환경 구성: 485. docker - SAP Adaptive Server Enterprise 컨테이너 실행 [1]
12192정성태3/14/202021125개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행
12191정성태3/14/202022398개발 환경 구성: 483. docker - OracleXE 컨테이너 실행 [1]
12190정성태3/14/202017210오류 유형: 606. Docker Desktop 업그레이드 시 "The process cannot access the file 'C:\Program Files\Docker\Docker\resources\dockerd.exe' because it is being used by another process."
12189정성태3/13/202022688개발 환경 구성: 482. Facebook OAuth 처리 시 상태 정보 전달 방법과 "유효한 OAuth 리디렉션 URI" 설정 규칙
12188정성태3/13/202028202Windows: 169. 부팅 시점에 실행되는 chkdsk 결과를 확인하는 방법
12187정성태3/12/202017283오류 유형: 605. NtpClient was unable to set a manual peer to use as a time source because of duplicate error on '...'.
12186정성태3/12/202018894오류 유형: 604. The SysVol Permissions for one or more GPOs on this domain controller and not in sync with the permissions for the GPOs on the Baseline domain controller.
12185정성태3/11/202019718오류 유형: 603. The browser service was unable to retrieve a list of servers from the browser master...
12184정성태3/11/202021700오류 유형: 602. Automatic certificate enrollment for local system failed (0x800706ba) The RPC server is unavailable. [3]
12183정성태3/11/202018878오류 유형: 601. Warning: DsGetDcName returned information for \\[...], when we were trying to reach [...].
12182정성태3/11/202020515.NET Framework: 901. C# Windows Forms - Vista/7 이후의 Progress Bar 업데이트가 느린 문제파일 다운로드1
12181정성태3/11/202020817기타: 76. 재현 가능한 최소한의 예제 프로젝트란? - 두 번째 예제파일 다운로드1
12180정성태3/10/202017509오류 유형: 600. "Docker Desktop for Windows" - EXPOSE 포트가 LISTENING 되지 않는 문제
12179정성태3/10/202028788개발 환경 구성: 481. docker - PostgreSQL 컨테이너 실행
12178정성태3/10/202021496개발 환경 구성: 480. Linux 운영체제의 docker를 위한 tcp 바인딩 추가 [1]
12177정성태3/9/202020651개발 환경 구성: 479. docker - MySQL 컨테이너 실행
12176정성태3/9/202020174개발 환경 구성: 478. 파일의 (sha256 등의) 해시 값(checksum) 확인하는 방법
12175정성태3/8/202020225개발 환경 구성: 477. "Docker Desktop for Windows"의 "Linux Container" 모드를 위한 tcp 바인딩 추가
12174정성태3/7/202019220개발 환경 구성: 476. DockerDesktopVM의 파일 시스템 접근 [3]
12173정성태3/7/202021000개발 환경 구성: 475. docker - SQL Server 2019 컨테이너 실행 [1]
12172정성태3/7/202025204개발 환경 구성: 474. docker - container에서 root 권한 명령어 실행(sudo)
12171정성태3/6/202020188VS.NET IDE: 143. Visual Studio - ASP.NET Core Web Application의 "Enable Docker Support" 옵션으로 달라지는 점 [1]
... 61  62  63  64  65  66  67  68  69  70  [71]  72  73  74  75  ...