다음을 통해 공유


방법: 오프라인이나 서버에서 사용할 데이터 캐싱

업데이트: 2007년 11월

적용 대상

이 항목의 정보는 지정된 Visual Studio Tools for Office 프로젝트 및 Microsoft Office 버전에만 적용됩니다.

프로젝트 형식

  • 문서 수준 프로젝트

Microsoft Office 버전

  • 2007 Microsoft Office system

  • Microsoft Office 2003

자세한 내용은 응용 프로그램 및 프로젝트 형식에 따라 사용 가능한 기능을 참조하십시오.

데이터 항목을 문서에서 캐시하도록 표시하여 오프라인에서 사용할 수 있습니다. 이렇게 하면 문서가 서버에 저장되어 있는 경우 문서의 데이터를 다른 코드로 조작할 수도 있습니다.

코드에서 데이터 항목을 선언한 경우 해당 데이터 항목을 캐시하도록 표시할 수 있으며, DataSet을 사용하는 경우에는 속성 창에서 속성을 설정하여 이를 표시할 수 있습니다. DataSet 또는 DataTable이 아닌 데이터 항목을 캐시하려면 해당 데이터 항목이 문서에서 캐시될 수 있는 조건을 충족하는지 확인합니다. 자세한 내용은 데이터 캐싱을 참조하십시오.

참고:

Visual Basic에서 Cached 및 WithEvents로 표시하여 만든 데이터 집합과 CacheInDocument 속성을 True로 설정하여 데이터 소스 창이나 도구 상자에서 끌어 놓은 데이터 집합의 캐시 이름 앞에는 밑줄(_)이 추가됩니다. 예를 들어, 데이터 집합을 만들고 그 이름을 Customers로 지정한 경우 캐시에서 CachedDataItem 이름은 _Customers가 됩니다. ServerDocument를 사용하여 이 캐시된 항목에 액세스하는 경우 Customers가 아닌 _Customers를 지정해야 합니다.

코드를 사용하여 문서에서 데이터를 캐시하려면

  1. 프로젝트에서 데이터 항목의 공용 필드 또는 속성을 ThisDocument 클래스(Word 프로젝트의 경우) 또는 ThisWorkbook 클래스(Excel 프로젝트의 경우)와 같은 호스트 항목 클래스의 멤버로 선언합니다.

  2. 이 멤버에 CachedAttribute 특성을 적용하여 데이터 항목을 문서의 데이터 캐시에 저장하도록 표시합니다. 다음 예제에서는 DataSet에 대한 필드 선언에 이 특성을 적용합니다.

    <Microsoft.VisualStudio.Tools.Applications.Runtime.Cached()> _
    Public employeesDataSet As DataSet
    
    [Microsoft.VisualStudio.Tools.Applications.Runtime.Cached()]
    public DataSet employeesDataSet;
    
  3. 데이터 항목의 인스턴스를 만들고 해당되는 경우 이를 데이터베이스에서 로드하는 코드를 추가합니다.

    데이터 항목은 해당 항목을 처음 만들 때만 로드됩니다. 이후에는 문서와 함께 캐시가 유지되므로 이를 업데이트하려면 다른 코드를 작성해야 합니다.

속성 창을 사용하여 문서에서 데이터 집합을 캐시하려면

  1. Visual Studio 디자이너의 도구를 사용하여 프로젝트에 데이터 집합을 추가합니다. 예를 들어 데이터 소스 창을 사용하여 프로젝트에 데이터 소스를 추가합니다.

  2. 데이터 집합의 인스턴스가 하나도 없으면 이를 만들고 디자이너에서 인스턴스를 선택합니다.

  3. 속성 창에서 CacheInDocument 속성을 True로 설정합니다.

    자세한 내용은 Visual Studio Tools for Office 프로젝트의 속성을 참조하십시오.

  4. 속성 창에서 Modifiers 속성을 Public으로 설정합니다. 기본값은 Internal입니다.

참고 항목

작업

방법: Office 문서에서 프로그래밍 방식으로 데이터 소스 캐싱

방법: 프로그래밍 방식으로 데이터 소스 캐싱 중지

방법: 암호로 보호된 문서의 데이터 캐시

개념

데이터 캐싱

서버에 있는 문서의 데이터 액세스

기타 리소스

데이터 저장

ADO.NET의 동시성 제어