데이터베이스 및 사용 권한 만들기(SQL Server 및 RevoScaleR 자습서)
적용 대상: SQL Server 2016(13.x) 이상 버전
이것은 SQL Server에서 RevoScaleR 함수를 사용하는 방법에 대한 RevoScaleR 자습서 시리즈 중 자습서 1에 해당됩니다.
이 자습서에서는 SQL Server 데이터베이스를 만들고 이 시리즈의 다른 자습서를 완료하는 데 필요한 권한을 설정하는 방법을 설명합니다. SQL Server Management Studio 또는 다른 쿼리 편집기를 사용하여 다음 작업을 완료합니다.
- 두 개의 R 모델 학습 및 점수 매기기에 사용되는 데이터를 저장할 새 데이터베이스 만들기
- 데이터베이스 개체 만들기 및 사용 권한이 있는 데이터베이스 사용자 로그인 만들기
데이터베이스 만들기
이 자습서에는 데이터 및 코드를 저장하는 데이터베이스가 필요합니다. 관리자가 아니라면 DBA에 데이터베이스를 생성하고 로그인하도록 요청합니다. 데이터를 쓰거나 읽고 R 스크립트를 실행하려면 권한이 필요합니다.
SQL Server Management Studio에서 R 사용 데이터베이스 인스턴스에 연결합니다.
데이터베이스를 마우스 오른쪽 단추로 클릭하고 새 데이터베이스를 선택합니다.
새 데이터베이스의 이름을 입력합니다. RevoDeepDive.
로그인을 만듭니다.
새 쿼리를 클릭하고 데이터베이스 컨텍스트를 master 데이터베이스로 변경합니다.
새 쿼리 창에서 다음 명령을 실행하여 사용자 계정을 만들고 이 자습서에 사용되는 데이터베이스에 할당합니다. 필요한 경우 데이터베이스 이름을 변경해야 합니다.
로그인을 확인하려면 새 데이터베이스를 선택하고 보안 및 사용자를 차례로 확장합니다.
Windows 사용자
-- Create server user based on Windows account
USE master
GO
CREATE LOGIN [<DOMAIN>\<user_name>] FROM WINDOWS WITH DEFAULT_DATABASE=[RevoDeepDive]
--Add the new user to tutorial database
USE [RevoDeepDive]
GO
CREATE USER [<user_name>] FOR LOGIN [<DOMAIN>\<user_name>] WITH DEFAULT_SCHEMA=[db_datareader]
SQL 로그인
-- Create new SQL login
USE master
GO
CREATE LOGIN [DDUser01] WITH PASSWORD='<type password here>', CHECK_EXPIRATION=OFF, CHECK_POLICY=OFF;
-- Add the new SQL login to tutorial database
USE RevoDeepDive
GO
CREATE USER [DDUser01] FOR LOGIN [DDUser01] WITH DEFAULT_SCHEMA=[db_datareader]
권한 할당
이 자습서에서는 테이블과 저장 프로시저 생성, 삭제 및 SQL Server의 외부 프로세스에서 R 스크립트실행을 포함하여 R 스크립트 및 DDL 작업을 보여 줍니다. 이 단계에서는 이러한 작업을 허용하도록 권한을 할당합니다.
이 예제에서는 SQL 로그인(DDUser01)을 가정하지만 Windows 로그인을 만든 경우 대신 이를 사용합니다.
USE RevoDeepDive
GO
EXEC sp_addrolemember 'db_owner', 'DDUser01'
GRANT EXECUTE ANY EXTERNAL SCRIPT TO DDUser01
GO
연결 문제 해결
이 섹션에서는 데이터베이스를 설정하는 과정에서 발생할 수 있는 몇 가지 일반적인 문제를 보여 줍니다.
데이터베이스 연결을 확인하고 SQL 쿼리를 검사하려면 어떻게 하나요?
서버를 사용하여 R 코드를 실행하기 전에 R 개발 환경에서 데이터베이스에 연결할 수 있는지 확인하는 것이 좋습니다. Visual Studio의 서버 탐색기 및 SQL Server Management Studio 는 둘 다 강력한 데이터베이스 연결 및 관리 기능을 갖춘 무료 도구입니다.
추가 데이터베이스 관리 도구를 설치하지 않으려는 경우 제어판의 ODBC 데이터 원본 관리자 를 사용하여 SQL Server 인스턴스에 대한 테스트 연결을 만들 수 있습니다. 데이터베이스가 올바르게 구성되고 올바른 사용자 이름 및 암호를 입력한 경우 방금 만든 데이터베이스가 표시되며 기본 데이터베이스로 선택할 수 있습니다.
연결 실패의 일반적인 이유로는 서버에 대한 원격 연결이 설정되어 있지 않으며 명명된 파이프 프로토콜이 활성화되어 있지 않습니다. 이 문서에서 더 많은 문제 해결 팁을 찾을 수 있습니다. SQL Server 데이터베이스 엔진 연결 문제를 해결합니다.
내 테이블 이름 앞에 datareader가 붙는 것은 무엇 때문인가요?
이 사용자에 대한 기본 스키마를 db_datareader로 지정하면 이 사용자가 만든 모든 테이블과 기타 새 개체 앞에 이 스키마 이름이 붙습니다. 스키마는 개체를 구성하기 위해 데이터베이스에 추가할 수 있는 폴더와 비슷합니다. 또한 스키마는 데이터베이스 내에서 사용자 권한을 정의합니다.
스키마가 하나의 특정 사용자 이름과 연결된 경우 사용자는 스키마 소유자입니다. 개체를 만들 때 다른 스키마에서 만들도록 요청하지 않을 경우 항상 고유한 스키마에서 만듭니다.
예를 들어 이름이 TestData인 테이블을 만들고 기본 스키마가 db_datareader이면 이름이
<database_name>.db_datareader.TestData
인 테이블이 만들어집니다.이러한 이유로 테이블이 서로 다른 스키마에 속하기만 하면 한 데이터베이스에 같은 이름의 테이블이 여러 개 포함될 수 있습니다.
테이블을 찾고 있으며 스키마를 지정하지 않을 경우 데이터베이스 서버는 사용자가 소유한 스키마를 찾습니다. 따라서 로그인과 연결된 스키마의 테이블에 액세스할 때는 스키마 이름을 지정하지 않아도 됩니다.
DDL 권한이 없습니다. 그래도 자습서를 실행할 수 있나요?=
예, 하지만 사용자에게 데이터를 SQL Server 테이블에 미리 로드하도록 요청하고 다음 자습서로 건너뛰어야 합니다. DDL 권한이 필요한 함수는 가능한 경우 자습서에서 호출됩니다.
또한 관리자에게 EXECUTE ANY EXTERNAL SCRIPT 권한을 부여하도록 요청합니다. 원격이든
sp_execute_external_script
를 사용하든 R 스크립트 실행에 필요합니다.