Date 차원 수정
이 항목의 태스크에서는 사용자 정의 계층을 만들고 Date, Month, Calendar Quarter, Calendar Semester 특성에 대해 표시되는 멤버 이름을 변경합니다. 또한 특성에 대한 복합 키를 정의하고 차원 멤버의 정렬 순서를 제어하고 특성 관계도 정의합니다.
명명된 계산 추가
계산 열로 표시되는 SQL 식인 명명된 계산을 데이터 원본 뷰의 테이블에 추가할 수 있습니다. 이 식은 테이블의 열로 나타나고 동작합니다. 명명된 계산을 사용하면 기본 데이터 원본의 테이블을 수정하지 않고 데이터 원본 뷰에서 기존 테이블의 관계형 스키마를 확장할 수 있습니다. 자세한 내용은 데이터 원본 뷰에서 명명된 계산 정의(Analysis Services)를 참조하십시오.
명명된 계산을 추가하려면
솔루션 탐색기의 데이터 원본 뷰 폴더에서 Adventure Works DW 데이터 원본 뷰를 두 번 클릭하여 엽니다.
테이블 창에서 Date를 마우스 오른쪽 단추로 클릭한 다음 새 명명된 계산을 클릭합니다.
명명된 계산 만들기 대화 상자에서 열 이름 상자에 SimpleDate를 입력하고 식 상자에 다음 CASE 문을 입력합니다.
DATENAME(mm, FullDateAlternateKey) + ' ' + DATENAME(dd, FullDateAlternateKey) + ', ' + DATENAME(yy, FullDateAlternateKey)
CASE 문은 FullDateAlternateKey 열에서 연도, 월 및 날짜 값을 추출합니다. 이 새 열을 FullDateAlternateKey 특성에 대한 표시 이름으로 사용합니다.
확인을 클릭한 다음 테이블 창에서 Date를 확장합니다.
명명된 계산임을 나타내는 아이콘과 함께 SimpleDate 명명된 계산이 Customer 테이블의 열 목록에 나타납니다.
파일 메뉴에서 모두 저장을 클릭합니다.
테이블 창에서 Date를 마우스 오른쪽 단추로 클릭하고 데이터 탐색을 선택합니다.
Customer 테이블 탐색 뷰의 마지막 열을 검토합니다.
원래 데이터 원본을 수정하지 않고 기본 데이터 원본에서 여러 열의 데이터를 올바르게 연결한 SimpleDate 열이 데이터 원본 뷰에 나타납니다.
Customer 테이블 탐색 뷰를 닫습니다.
멤버 이름에 명명된 계산 사용
데이터 원본 뷰에서 명명된 계산을 만든 후에는 이 명명된 계산을 특성의 속성으로 사용할 수 있습니다.
멤버 이름에 명명된 계산을 사용하려면
Business Intelligence Development Studio에서 Date 차원에 대한 차원 디자이너를 엽니다. 이렇게 하려면 솔루션 탐색기의 차원 노드에서 Date 차원을 두 번 클릭합니다.
차원 구조 탭의 특성 창에서 Date Key 특성을 클릭합니다.
속성 창을 열고 제목 표시줄의 자동 숨기기 단추를 클릭하여 열린 상태를 유지하도록 합니다.
NameColumn 속성 필드를 클릭한 다음 줄임표(…) 단추를 클릭하여 이름 열 대화 상자를 엽니다.
원본 열 목록에서 SimpleDate를 선택하고 확인을 클릭합니다.
파일 메뉴에서 모두 저장을 클릭합니다.
계층 만들기
특성 창에서 계층 창으로 특성을 끌어 새 계층을 만들 수 있습니다.
계층을 만들려면
Key 차원에 대한 차원 디자이너에서 특성 창의 Calendar Year 특성을 계층 창으로 끌어 옵니다.
특성 창의 Calendar Semester 특성을 계층 창의 Calendar Year 수준 아래 <새 수준> 셀에 끌어 옵니다.
특성 창의 Calendar Quarter 특성을 계층 창의 Calendar Semester 수준 아래 <새 수준> 셀에 끌어 옵니다.
특성 창의 English Month Name 특성을 계층 창의 Calendar Quarter 수준 아래 <새 수준> 셀에 끌어 옵니다.
특성 창의 Date Key 특성을 계층 창의 English Month Name 수준 아래 <새 수준> 셀에 끌어 옵니다.
계층 창에서 Hierarchy 계층의 제목 표시줄을 마우스 오른쪽 단추로 클릭하고 이름 바꾸기를 선택한 다음 Calendar Date를 입력합니다.
Calendar Date 계층에서 English Month Name 수준의 이름을 Calendar Month로 변경하고 Date Key 수준의 이름을 Date로 변경합니다.
FullDateAlternateKey 특성은 사용하지 않으므로 특성 창에서 삭제합니다.
파일 메뉴에서 모두 저장을 클릭합니다.
특성 관계 정의
기본 데이터가 특성 관계를 지원하는 경우 특성 간의 특성 관계를 정의해야 합니다. 특성 관계를 정의하면 차원, 파티션 및 쿼리 처리가 빨라집니다.
특성 관계를 정의하려면
Date 차원의 차원 디자이너에서 특성 관계 탭을 클릭합니다.
다이어그램에서 English Month Name 특성을 마우스 오른쪽 단추로 클릭한 다음 새 특성 관계를 선택합니다.
특성 관계 만들기 대화 상자에서 원본 특성은 English Month Name입니다. 관련 특성을 Calendar Quarter로 설정합니다.
관계 유형 목록에서 관계 유형을 고정으로 설정합니다.
멤버 간의 관계는 시간이 지나도 변경되지 않으므로 관계 유형은 고정입니다.
확인을 클릭합니다.
다이어그램에서 Calendar Quarter 특성을 마우스 오른쪽 단추로 클릭한 다음 새 특성 관계를 선택합니다.
특성 관계 만들기 대화 상자에서 원본 특성은 Calendar Quarter입니다. 관련 특성을 Calendar Semester로 설정합니다.
관계 유형 목록에서 관계 유형을 고정으로 설정합니다.
확인을 클릭합니다.
다이어그램에서 Calendar Semester 특성을 마우스 오른쪽 단추로 클릭한 다음 새 특성 관계를 선택합니다.
특성 관계 만들기 대화 상자에서 원본 특성은 Calendar Semester입니다. 관련 특성을 Calendar Year로 설정합니다.
관계 유형 목록에서 관계 유형을 고정으로 설정합니다.
확인을 클릭합니다.
파일 메뉴에서 모두 저장을 클릭합니다.
고유한 차원 멤버 이름 지정
이 태스크에서는 EnglishMonthName, CalendarQuarter, CalendarSemester 특성에서 사용되는 친숙한 이름 열을 만듭니다.
고유한 차원 멤버 이름을 지정하려면
솔루션 탐색기의 데이터 원본 뷰 폴더에서 Adventure Works DW 데이터 원본 뷰를 두 번 클릭하여 이 뷰로 전환합니다.
테이블 창에서 Date를 마우스 오른쪽 단추로 클릭한 다음 새 명명된 계산을 클릭합니다.
명명된 계산 만들기 대화 상자에서 열 이름 상자에 MonthName을 입력하고 식 상자에 다음 문을 입력합니다.
EnglishMonthName+' '+ CONVERT(CHAR (4), CalendarYear)
이 문은 DimTime 테이블에 있는 월 및 각 월의 연도를 새 열에 연결합니다.
확인을 클릭합니다.
테이블 창에서 Date를 마우스 오른쪽 단추로 클릭한 다음 새 명명된 계산을 클릭합니다.
명명된 계산 만들기 대화 상자에서 열 이름 상자에 CalendarQuarterDesc를 입력하고 식 상자에 다음 SQL 스크립트를 입력합니다.
'Q' + CONVERT(CHAR (1), CalendarQuarter) +' '+ 'CY ' + CONVERT(CHAR (4), CalendarYear)
이 SQL 스크립트는 DimTime 테이블에 있는 분기와 각 분기의 연도를 새 열에 연결합니다.
확인을 클릭합니다.
테이블 창에서 Date를 마우스 오른쪽 단추로 클릭한 다음 새 명명된 계산을 클릭합니다.
명명된 계산 만들기 대화 상자에서 열 이름 상자에 CalendarSemesterDesc를 입력하고 식 상자에 다음 SQL 스크립트를 입력합니다.
CASE WHEN CalendarSemester = 1 THEN 'H1' + ' ' + 'CY' + ' ' + CONVERT(CHAR(4), CalendarYear) ELSE 'H2' + ' ' + 'CY' + ' ' + CONVERT(CHAR(4), CalendarYear) END
이 SQL 스크립트는 DimTime 테이블에 있는 반기와 각 반기의 연도를 새 열에 연결합니다.
확인을 클릭합니다.
파일 메뉴에서 모두 저장을 클릭합니다.
복합 KeyColumns 정의 및 이름 열 설정
KeyColumns 속성에는 특성의 키를 나타내는 열이 포함됩니다. 이 태스크에서는 복합 KeyColumns를 정의합니다.
English Month Name 특성에 대한 복합 KeyColumns를 정의하려면
Date 차원에 대한 차원 구조 탭을 엽니다.
특성 창에서 English Month Name 특성을 클릭합니다.
속성 창에서 KeyColumns 필드를 클릭한 다음 찾아보기(...) 단추를 클릭합니다.
키 열 대화 상자의 사용 가능한 열 목록에서 CalendarYear 열을 선택한 후 > 단추를 클릭합니다.
EnglishMonthName 및 CalendarYear 열이 키 열 목록에 표시됩니다.
확인을 클릭합니다.
EnglishMonthName 특성의 NameColumn 속성을 설정하려면 속성 창의 NameColumn 필드를 클릭한 후 찾아보기(...) 단추를 클릭합니다.
이름 열 대화 상자의 원본 열 목록에서 MonthName을 선택한 후 확인을 클릭합니다.
파일 메뉴에서 모두 저장을 클릭합니다.
Calendar Quarter 특성에 대한 복합 KeyColumns를 정의하려면
특성 창에서 Calendar Quarter 특성을 클릭합니다.
속성 창에서 KeyColumns 필드를 클릭한 다음 찾아보기(...) 단추를 클릭합니다.
키 열 대화 상자의 사용 가능한 열 목록에서 CalendarYear 열을 선택한 후 > 단추를 클릭합니다.
CalendarQuarter 및 CalendarYear 열이 키 열 목록에 표시됩니다.
확인을 클릭합니다.
Calendar Quarter 특성의 NameColumn 속성을 설정하려면 속성 창의 NameColumn 필드를 클릭한 후 찾아보기(...) 단추를 클릭합니다.
이름 열 대화 상자의 원본 열 목록에서 CalendarQuarterDesc를 선택한 후 확인을 클릭합니다.
파일 메뉴에서 모두 저장을 클릭합니다.
Calendar Semester 특성에 대한 복합 KeyColumns를 정의하려면
특성 창에서 Calendar Semester 특성을 클릭합니다.
속성 창에서 KeyColumns 필드를 클릭한 다음 찾아보기(...) 단추를 클릭합니다.
키 열 대화 상자의 사용 가능한 열 목록에서 CalendarYear 열을 선택한 후 > 단추를 클릭합니다.
CalendarSemester 및 CalendarYear 열이 키 열 목록에 표시됩니다.
확인을 클릭합니다.
Calendar Semester 특성의 NameColumn 속성을 설정하려면 속성 창의 NameColumn 필드를 클릭한 후 찾아보기(...) 단추를 클릭합니다.
이름 열 대화 상자의 원본 열 목록에서 CalendarSemesterDesc를 선택한 후 확인을 클릭합니다.
파일 메뉴에서 모두 저장을 클릭합니다.
변경 내용 배포 및 표시
특성과 계층을 변경한 후에 변경 내용을 표시하려면 먼저 변경 내용을 배포하고 관련 개체를 다시 처리해야 합니다.
변경 내용을 배포하고 표시하려면
BI Development Studio의 빌드 메뉴에서 Analysis Services Tutorial 배포를 클릭합니다.
배포가 완료되었습니다. 메시지를 받은 후 Date 차원에 대한 차원 디자이너의 브라우저 탭을 클릭한 다음 디자이너의 도구 모음에 있는 다시 연결 아이콘을 클릭합니다.
계층 목록에서 Calendar Quarter를 선택합니다. Calendar Quarter 특성 계층의 멤버를 검토합니다.
이름으로 사용할 명명된 계산을 만든 덕분에 Calendar Quarter 특성 계층의 멤버 이름이 보다 친숙함을 확인할 수 있습니다. 이제 멤버는 연도별 각 분기에 대한 Calendar Quarter 특성 계층에 있지만 멤버가 시간순으로 정렬되지 않고 분기순으로 정렬된 다음 연도순으로 정렬됩니다. 이 항목의 다음 태스크에서는 이 동작을 수정하여 이 특성 계층의 멤버를 연도순으로 정렬한 다음 분기순으로 정렬합니다.
English Month Name 및 Calendar Semester 특성 계층의 멤버를 검토합니다.
이 계층의 멤버도 시간순으로 정렬되지 않고 각각 월이나 반기순으로 정렬된 다음 연도순으로 정렬됩니다. 이 항목의 다음 태스크에서는 이 동작을 수정하여 이 정렬 순서를 변경합니다.
복합 키 멤버 순서를 수정하여 정렬 순서 변경
이 태스크에서는 복합 키를 구성하는 키의 순서를 변경하여 정렬 순서를 변경합니다.
복합 키 멤버 순서를 수정하려면
Date 차원에 대한 차원 디자이너의 차원 구조 탭을 선택한 다음 특성 창에서 Calendar Semester를 선택합니다.
속성 창에서 OrderBy 속성 값을 검토합니다. 키로 설정되어 있습니다.
Calendar Semester 특성 계층의 멤버는 키 값을 기준으로 정렬됩니다. 복합 키를 사용하면 멤버 키가 먼저 첫 번째 멤버 키의 값을 기준으로 정렬된 다음 두 번째 멤버 키 값을 기준으로 정렬됩니다. 즉 Calendar Semester 특성 계층의 멤버는 먼저 반기순으로 정렬된 다음 연도순으로 정렬됩니다.
속성 창에서 줄임표 단추(...)를 클릭하여 KeyColumns 속성 값을 변경합니다.
키 열 대화 상자의 키 열 목록에서 CalendarSemester가 선택되어 있는지 확인한 후 아래쪽 화살표를 클릭하여 이 복합 키 멤버의 순서를 반대로 바꿉니다. 확인을 클릭합니다.
이제 특성 계층의 멤버가 연도순으로 정렬된 다음 반기순으로 정렬됩니다.
특성 창에서 Calendar Quarter를 선택하고 속성 창에서 KeyColumns 속성의 줄임표 단추(...)를 클릭합니다.
키 열 대화 상자의 키 열 목록에서 CalendarQuarter가 선택되어 있는지 확인한 후 아래쪽 화살표를 클릭하여 이 복합 키 멤버의 순서를 반대로 바꿉니다. 확인을 클릭합니다.
이제 특성 계층의 멤버가 연도순으로 정렬된 다음 분기순으로 정렬됩니다.
특성 창에서 English Month Name을 선택하고 속성 창에서 KeyColumns 속성의 줄임표 단추(...)를 클릭합니다.
키 열 대화 상자의 키 열 목록에서 EnglishMonthName이 선택되어 있는지 확인한 후 아래쪽 화살표를 클릭하여 이 복합 키 멤버의 순서를 반대로 바꿉니다. 확인을 클릭합니다.
이제 특성 계층의 멤버가 연도순으로 정렬된 다음 월순으로 정렬됩니다.
BI Development Studio의 빌드 메뉴에서 Analysis Services Tutorial 배포를 클릭합니다. 배포가 성공적으로 완료되면 Date 차원에 대한 차원 디자이너에서 브라우저 탭을 클릭합니다.
브라우저 탭의 도구 모음에서 다시 연결 아이콘을 클릭합니다.
Calendar Quarter 및 Calendar Semester 특성 계층의 멤버를 검토합니다.
이 계층의 멤버는 이제 시간순으로 정렬되고 연도순으로 정렬된 다음 각각 분기순이나 반기순으로 정렬됩니다.
English Month Name 특성 계층의 멤버를 검토합니다.
이제 계층의 멤버가 연도순으로 정렬된 다음 월 이름의 사전순으로 정렬됩니다. 이는 기본 관계형 데이터베이스의 nvarchar 데이터 형식에 기초하여 데이터 원본 뷰의 EnglishCalendarMonth 열에 대한 데이터 형식이 문자열 열이기 때문입니다. 각 연도 내에서 월을 시간 순으로 정렬하는 방법은 보조 특성을 기준으로 특성 멤버 정렬을 참조하십시오.