1단원: RDL Schema Visual Studio 프로젝트 만들기
이 자습서에서는 간단한 콘솔 응용 프로그램을 만듭니다. 개발은 Microsoft Visual Studio 2008에서 수행한다고 가정합니다.
[!참고]
SQL Server Express with Advanced Services에서 실행되는 보고서 서버 웹 서비스에 액세스하는 경우 "ReportServer" 경로에 "_SQLExpress"를 추가해야 합니다. 예를 들면 다음과 같습니다.
http://myserver/reportserver_sqlexpress/reportservice2010.asmx"
웹 서비스 프록시를 만들려면
시작 메뉴에서 모든 프로그램, Microsoft Visual Studio, Visual Studio 도구, Visual Studio 2008 명령 프롬프트를 차례로 선택합니다.
명령 프롬프트 창에서 C#을 사용 중인 경우 다음 명령을 실행합니다.
wsdl /language:CS /n:"ReportService2010" http://<Server Name>/reportserver/reportservice2010.asmx?wsdl
Visual Basic을 사용 중인 경우 다음 명령을 실행합니다.
wsdl /language:VB /n:"ReportService2010" http://<Server Name>/reportserver/reportservice2010.asmx?wsdl
.cs 또는 .vb 파일이 생성됩니다. 이 파일을 응용 프로그램에 추가합니다.
콘솔 응용 프로그램을 만들려면
파일 메뉴에서 새로 만들기를 가리킨 다음 프로젝트를 클릭하여 새 프로젝트 대화 상자를 엽니다.
프로젝트 형식 창에서 Visual Basic 또는 Visual C# 노드를 클릭합니다.
콘솔 응용 프로그램 아이콘을 클릭합니다.
이름 입력란에 프로젝트 이름을 SampleRDLSchema로 입력합니다.
위치 상자에 프로젝트를 저장할 경로를 입력하거나 찾아보기를 클릭하여 원하는 폴더로 이동합니다.
확인을 클릭합니다. 프로젝트가 축소된 상태로 솔루션 탐색기에 나타납니다.
프로젝트 메뉴에서 기존 항목 추가를 클릭합니다.
생성된 .cs 또는 .vb 파일의 위치로 이동한 다음 파일을 선택하고 추가를 클릭합니다.
웹 참조가 작동할 수 있도록 System.Web.Services 네임스페이스에 대한 참조도 추가해야 합니다.
프로젝트 메뉴에서 참조 추가를 클릭합니다.
참조 추가 대화 상자의 .NET 탭에서 System.Web.Services를 선택하고 확인을 클릭합니다.
보고서 서버 웹 서비스에 연결하는 방법은 웹 서비스 및 .NET Framework를 사용하여 응용 프로그램 작성를 참조하십시오.
솔루션 탐색기에서 프로젝트 노드를 확장합니다. Program.cs(Visual Basic의 경우 Module1.vb)라는 기본 이름을 가진 코드 파일이 프로젝트에 추가되었음을 확인할 수 있습니다.
Program.cs(Visual Basic의 경우 Module1.vb) 파일을 열고 이 코드를 다음 코드로 바꿉니다.
다음 코드는 로드, 업데이트 및 저장 기능을 구현하는 데 사용할 메서드 스텁을 제공합니다.
using System; using System.Collections.Generic; using System.IO; using System.Text; using System.Xml; using System.Xml.Serialization; using ReportService2010; namespace SampleRDLSchema { class ReportUpdater { ReportingService2010 _reportService; static void Main(string[] args) { ReportUpdater reportUpdater = new ReportUpdater(); reportUpdater.UpdateReport(); } private void UpdateReport() { try { // Set up the Report Service connection _reportService = new ReportingService2010(); _reportService.Credentials = System.Net.CredentialCache.DefaultCredentials; _reportService.Url = "http://<Server Name>/reportserver/" + "reportservice2010.asmx"; // Call the methods to update a report definition LoadReportDefinition(); UpdateReportDefinition(); PublishReportDefinition(); } catch (Exception ex) { System.Console.WriteLine(ex.Message); } } private void LoadReportDefinition() { //Lesson 2: Load a report definition from the report // catalog } private void UpdateReportDefinition() { //Lesson 3: Update the report definition using the // classes generated from the RDL Schema } private void PublishReportDefinition() { //Lesson 4: Publish the updated report definition back // to the report catalog } } }
Imports System Imports System.Collections.Generic Imports System.IO Imports System.Text Imports System.Xml Imports System.Xml.Serialization Imports ReportService2010 Namespace SampleRDLSchema Module ReportUpdater Private m_reportService As ReportingService2010 Public Sub Main(ByVal args As String()) Try 'Set up the Report Service connection m_reportService = New ReportingService2010 m_reportService.Credentials = _ System.Net.CredentialCache.DefaultCredentials m_reportService.Url = _ "http:// <Server Name>/reportserver/" & _ "reportservice2010.asmx" 'Call the methods to update a report definition LoadReportDefinition() UpdateReportDefinition() PublishReportDefinition() Catch ex As Exception System.Console.WriteLine(ex.Message) End Try End Sub Private Sub LoadReportDefinition() 'Lesson 2: Load a report definition from the report ' catalog End Sub Private Sub UpdateReportDefinition() 'Lesson 3: Update the report definition using the ' classes generated from the RDL Schema End Sub Private Sub PublishReportDefinition() 'Lesson 4: Publish the updated report definition back ' to the report catalog End Sub End Module End Namespace
다음 단원
다음 단원에서는 XML 스키마 정의 도구(Xsd.exe)를 사용하여 RDL 스키마의 클래스를 생성하고 이를 프로젝트에 포함시킵니다. 2단원: xsd 도구를 사용하여 RDL 스키마에서 클래스 생성을 참조하십시오.