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)
12212정성태5/1/202016763개발 환경 구성: 487. UEFI / Secure Boot 상태인지 확인하는 방법
12211정성태4/27/202019337개발 환경 구성: 486. WSL에서 Makefile로 공개된 리눅스 환경의 C/C++ 소스 코드 빌드
12210정성태4/20/202020820.NET Framework: 903. .NET Framework의 Strong-named 어셈블리 바인딩 (1) - app.config을 이용한 바인딩 리디렉션 [1]파일 다운로드1
12209정성태4/13/202017487오류 유형: 614. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우 (2)
12208정성태4/12/202016089Linux: 29. 리눅스 환경에서 C/C++ 프로그램이 Segmentation fault 에러가 발생한 경우
12207정성태4/2/202015994스크립트: 19. Windows PowerShell의 NonInteractive 모드
12206정성태4/2/202018531오류 유형: 613. 파일 잠금이 바로 안 풀린다면? - The process cannot access the file '...' because it is being used by another process.
12205정성태4/2/202015195스크립트: 18. Powershell에서는 cmd.exe의 명령어를 지원하진 않습니다.
12204정성태4/1/202015226스크립트: 17. Powershell 명령어에 ';' (semi-colon) 문자가 포함된 경우
12203정성태3/18/202018075오류 유형: 612. warning: 'C:\ProgramData/Git/config' has a dubious owner: '...'.
12202정성태3/18/202021293개발 환경 구성: 486. .NET Framework 프로젝트를 위한 GitLab CI/CD Runner 구성
12201정성태3/18/202018547오류 유형: 611. git-credential-manager.exe: Using credentials for username "Personal Access Token". [1]
12200정성태3/18/202018635VS.NET IDE: 145. NuGet + Github 라이브러리 디버깅 관련 옵션 3가지 - "Enable Just My Code" / "Enable Source Link support" / "Suppress JIT optimization on module load (Managed only)"
12199정성태3/17/202016279오류 유형: 610. C# - CodeDomProvider 사용 시 Unhandled Exception: System.IO.DirectoryNotFoundException: Could not find a part of the path '...\f2_6uod0.tmp'.
12198정성태3/17/202019609오류 유형: 609. SQL 서버 접속 시 "Cannot open user default database. Login failed."
12197정성태3/17/202018977VS.NET IDE: 144. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 - 두 번째 이야기 [1]
12196정성태3/17/202016037오류 유형: 608. The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
12195정성태3/16/202018393.NET Framework: 902. C# - 프로세스의 모든 핸들을 열람 - 세 번째 이야기
12194정성태3/16/202021047오류 유형: 607. PostgreSQL - Npgsql.NpgsqlException: sorry, too many clients already
12193정성태3/16/202018076개발 환경 구성: 485. docker - SAP Adaptive Server Enterprise 컨테이너 실행 [1]
12192정성태3/14/202020046개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행
12191정성태3/14/202021141개발 환경 구성: 483. docker - OracleXE 컨테이너 실행 [1]
12190정성태3/14/202015762오류 유형: 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/202021348개발 환경 구성: 482. Facebook OAuth 처리 시 상태 정보 전달 방법과 "유효한 OAuth 리디렉션 URI" 설정 규칙
12188정성태3/13/202026145Windows: 169. 부팅 시점에 실행되는 chkdsk 결과를 확인하는 방법
12187정성태3/12/202015749오류 유형: 605. NtpClient was unable to set a manual peer to use as a time source because of duplicate error on '...'.
... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...