본문 바로가기
데이터베이스/MS-SQL

sa 계정 비밀번호 변경 방법

by MonoSoft 2022. 12. 20.
728x90
반응형

sa 계정 비밀번호 변경 방법

 

SQL Server 인스턴스를 만들 때 인증 방식을 혼합 모드로 만들어서

sa 계정을 만들어 놓고 그 뒤로 윈도우 인증 방식으로만 접속하다보니

sa 계정 비밀번호를 잊어버리는 사태가 발생한 적이 있었다..

 

이 때 sa 계정이 필요했던 이유는 윈도우 인증 방식이

[컴퓨터 이름]\[인스턴스 이름]으로 인증하기 때문에

컴퓨터 이름을 변경하면서 사용할 수 없어졌기 때문이다.

 

이번 포스팅은 sa 계정 비밀번호를 변경하기 위해

여러 번의 구글링과 몇 번의 오류를 해결한 뒤에 성공했던 여정을 기록한 글이다.

 

시작!

 

먼저, 컴퓨터 이름을 다시 기존 이름으로 바꾼 뒤

윈도우 인증 방식으로 SQL Server에 접속한다.

 

[개체 탐색기]에서 서버 이름을 우클릭한 뒤 [속성] > [보안] > [서버 인증]에 들어가서

[SQL Server 및 Windows 인증모드(S)]로 인증 방법을 변경한다.

 

 

이제 [개체 탐색기]에 있는 서버의 하위 목록인 [보안] > [로그인] 으로 들어가면 sa가 있는데

이를 더블클릭하면 아래 화면이 나온다. 여기서 암호를 변경한 뒤 SQL Server 구성관리자에서

인스턴스를 재시작하면 된다.

 

이후에 변경한 sa 계정으로 접속해도 "접속할 수 없다"라는 오류가 발생하는 경우, 

암호가 제대로 변경되지 않을 수도 있기 때문에 cmd를 관리자모드로 

실행 후 아래 명령어를 통해 암호를 변경해 줘야 한다.

 

osql -E 는 윈도우 인증 방식으로 SQL Server 인스턴스 접속하라는 명령어이다.

 

> osql -E

> EXEC sp_password NULL, '원하는 패스워드', 'sa'

> GO

 

이렇게 해서 성공하면 좋겠지만 내 경우에는 접속을 시도하니 아래와 같은 오류가 발생했다.

 

"서버에는 연결했지만 로그인 하는 동안 오류가 발생했습니다.

(provider: 공유메모리 공급자. error: 0 - 파이프의 다른 끝에 프로세스가 없습니다.)"

 

이를 해결하기 위해 SQL Server 구성관리자에 들어가서 아래 화면과 같이

네트워크 구성 > 프로토콜 > TCP/IP를 "사용" 으로 변경한 뒤

SQL Server 구성관리자에서 인스턴스를 재시작했다.

이렇게까지 했는데도 위와 동일한 오류가 발생한다면,

cmd 관리자모드에서 아래 명령어를 입력한다.

이는 인터넷 연결 문제가 있을 때 TCP/IP 설정 정보들을 초기상태로 돌리는 작업이다.

 

> netsh Winsock reset

 

그리고 나서 컴퓨터를 재부팅한 후 또 다시

SQL Server 구성관리자에서 인스턴스를 재시작한다.

그렇게 다시한번 sa 계정으로 접속해 보았으나 다음의 오류가 발생했다.

 

[ 오류 : 18470 ] 계정을 사용할 수 없습니다.

 

이는 sa 계정으로 로그인이 비활성화 되었기 때문에 발생하는 오류로,

SQL Server에 윈도우 인증방식으로 접속 후 쿼리 창에 아래 쿼리를 실행해 sa계정을 활성화 하면 된다.

 

ALTER LOGIN [sa] ENABLE

 

이렇게 하고 다시 sa 계정으로 로그인하니 그제서야 접속에 성공했다!!

 

728x90
반응형

'데이터베이스 > MS-SQL' 카테고리의 다른 글

MS-SQL 트리거  (0) 2022.12.22
MSSQL HASHBYTES  (0) 2022.12.21
MSSQL 설치형 한글 환경으로 변경  (0) 2022.12.19
MS SQL Server 2019 Express 설치 방법  (0) 2022.12.16
MS-SQL 숫자 함수 CELLING, FLOOR, ROUND  (0) 2022.12.13

댓글