Sdílet prostřednictvím


Návod: Vložení dat do sešitu na serveru

Tento návod ukazuje, jak vložit data do objektu dataset, který je uložen do mezipaměti v aplikaci Microsoft Office Excel sešit bez spuštění aplikace Excel pomocí ServerDocument třídy.

Platí pro: Informace v tomto tématu se vztahují na projekty na úrovni dokumentu v Excelu 2013 a v Excelu 2010. Další informace najdete v tématu Dostupné funkce podle aplikací systému Office a typů projektu.

Tento návod ilustruje následující úkoly:

  • Definování dataset, který obsahuje data z databáze AdventureWorksLT.

  • Vytvoření instance objektu DataSet v projektu sešitu aplikace Excel a projekt konzolové aplikace.

  • Vytváření ListObject který je vázán na objekt dataset v sešitu.

  • Přidání objektu dataset v sešitu do mezipaměti data.

  • Vkládání dat do datové sady v mezipaměti po spuštění kódu v aplikaci konzoly bez spuštění aplikace Excel.

Přestože tento návod předpokládá, že používáte kód na vašem vývojovém počítači, kód prokázat v tomto návodu lze použít na serveru, který nemá nainstalovanou aplikaci Excel.

[!POZNÁMKA]

Váš počítač může zobrazit jiné názvy nebo umístění pro některé prvky uživatelského rozhraní sady Visual Studio v následujících pokynech.Tyto prvky jsou určeny verzí aplikace Visual Studio a použitým nastavením.Další informace naleznete v tématu Přizpůsobení nastavení pro vývoj v sadě Visual Studio.

Požadavky

Chcete-li dokončit tento návod, potřebujete následující komponenty:

Vytváření projektu knihovny tříd, který definuje třídu Dataset

Použití stejného objektu dataset v projektu sešitu aplikace Excel a konzolové aplikace, je nutné definovat datové sady v samostatném sestavení, který odkazuje obou těchto projektů.V tomto návodu definujte datové sady v projektu knihovny tříd.

Vytvoření projektu knihovny tříd

  1. Spusťte nástroj Visual Studio.

  2. V nabídce File (Soubor) přejděte na příkaz New (Nový) a klepněte na příkaz Project (Projekt).

  3. Rozbalte v podokně šablony Visual C# nebo jazyka Visual Basica potom klepněte na tlačítko Windows.

  4. V seznamu šablon projektů vyberte Knihovny tříd.

  5. V jméno zadejte AdventureWorksDataSet.

  6. Klepněte na tlačítko Procházet, přejděte na %UserProfile%\My dokumenty (pro systém Windows XP a starší) nebo %UserProfile%\Documents (pro systém Windows Vista) složky a klepněte na tlačítko Vybrat složku.

  7. V Nový projekt dialogové okno pole, ujistěte se, že vytvořit adresář pro řešení políčko není zaškrtnuto.

  8. Klikněte na tlačítko OK.

    Visual StudioPřidá AdventureWorksDataSet projektu na Průzkumníku a otevře Class1.cs nebo Class1.vb soubor kódu.

  9. V Průzkumníku, klepněte pravým tlačítkem Class1.cs nebo Class1.vba potom klepněte na tlačítko Odstranit.Není nutné tento soubor v tomto návodu.

Definování objekt Dataset v projektu knihovny tříd

Definujte definovanou datovou sadu, která obsahuje data z databáze AdventureWorksLT pro SQL Server 2005.Dále v tomto návodu bude odkazovat tento objekt dataset z projektu sešitu aplikace Excel a projekt konzolové aplikace.

Objekt dataset je zadaný objekt dataset , která představuje data v tabulce Product v databázi AdventureWorksLT.Další informace o typových datových sad naleznete v tématu Práce s datovými sadami v sadě Visual Studio.

Chcete-li definovat typované sady dat v projektu knihovny tříd

  1. V Průzkumníku, klepněte AdventureWorksDataSet projektu.

  2. Pokud Zdroje dat okno není zobrazen, zobrazit, na nabídek, výběr zobrazení, Ostatní okna, Zdroje dat.

  3. Zvolte Přidat nový zdroj dat ke spuštění Průvodce konfigurací zdroje dat.

  4. Klepněte na tlačítko databázea potom klepněte na tlačítko Další.

  5. Pokud máte existující připojení k databázi AdventureWorksLT, zvolte toto připojení a klepněte na Další.

    V opačném případě klepněte na tlačítko Nové připojenía použít Přidat připojení dialogové okno k vytvoření nového připojení.Další informace naleznete v tématu Návod: Vložení dat do sešitu na serveru.

  6. In the Save the Connection String to the Application Configuration File page, click Next.

  7. V Zvolte vaše databázové objekty stránky, rozbalte položku tabulky a vyberte produkt (SalesLT).

  8. Klepněte na tlačítko Dokončit.

    Je do souboru AdventureWorksLTDataSet.xsd AdventureWorksDataSet projektu.Tento soubor definuje následující položky:

    • Zadaný objekt dataset s názvem AdventureWorksLTDataSet.Tento objekt dataset představuje obsah tabulce Product v databázi AdventureWorksLT.

    • A TableAdapter named ProductTableAdapter.To TableAdapter lze použít ke čtení a zápisu dat v AdventureWorksLTDataSet.Další informace naleznete v tématu TableAdapter – přehled.

    Oba tyto objekty bude používat později v tomto návodu.

  9. V Průzkumníku, klepněte pravým tlačítkem AdventureWorksDataSet a klepněte na tlačítko sestavení.

    Ověřte, že projekt sestaví bez chyb.

Vytváření projektu sešitu aplikace Excel

Vytvořte projekt sešitu aplikace Excel pro rozhraní s daty.Dále v tomto návodu vytvoříte ListObject zobrazující data a přidáte instanci objektu dataset do mezipaměti data v sešitu.

Chcete-li vytvořit projekt sešitu aplikace Excel

  1. V Průzkumníku, klepněte pravým tlačítkem myši AdventureWorksDataSet řešení, přejděte na příkaz Přidata potom klepněte na tlačítko Nový projekt.

  2. Rozbalte v podokně šablony Visual C# nebo jazyka Visual Basica potom rozbalte uzel Office/SharePoint.

  3. V rámci rozšířeného Office/SharePoint uzel, vyberte Doplňky sady Office uzlu.

  4. Vyberte v seznamu šablon projektů, Sešit aplikace Excel 2010 nebo 2013 sešit aplikace Excel projektu.

  5. V jméno zadejte AdventureWorksReport.Neupravujte umístění.

  6. Klikněte na tlačítko OK.

    Visual Studio Tools for Office Project Wizard otevře.

  7. Zajistit, aby vytvořit nový dokument je vybrán a klepněte na tlačítko OK.

    Visual StudioOtevře AdventureWorksReport sešitu v návrháři a přidá AdventureWorksReport projektu na Průzkumníku.

Přidání objektu Dataset ke zdrojům dat v projektu sešitu aplikace Excel

Než budete moci zobrazit objekt dataset v sešitu aplikace Excel, je nutné přidat objekt dataset ke zdrojům dat v projektu sešitu aplikace Excel.

Chcete-li přidat objekt dataset ke zdrojům dat v projektu sešitu aplikace Excel

  1. V Průzkumníku, poklepejte na Sheet1.cs nebo Sheet1.vb pod AdventureWorksReport projektu.

    Sešit se otevře v návrháři.

  2. Na dat nabídky, klepněte na tlačítko Přidat nový zdroj dat.

    Otevře se Průvodce konfigurací zdroje dat.

  3. Klepněte na tlačítko objekta potom klepněte na tlačítko Další.

  4. V Vyberte objekt chcete vytvořit vazbu stránky, klepněte na tlačítko Přidat odkaz na.

  5. Na projekty karta, klepněte na tlačítko AdventureWorksDataSet a potom klepněte na tlačítko OK.

  6. Ve skupinovém rámečku AdventureWorksDataSet oboru názvů AdventureWorksDataSet sestavení, klepněte na tlačítko AdventureWorksLTDataSet a potom klepněte na tlačítko Dokončit.

    Zdroje dat se otevře okno, a AdventureWorksLTDataSet je přidán do seznamu datových zdrojů.

Vytvoření objektu ListObject, který je vázán na instanci objektu Dataset

Chcete-li zobrazit objekt dataset v sešitu, vytvořte ListObject který je vázán na instanci objektu dataset.Další informace o vázání ovládacích prvků na data naleznete v tématu Vázání dat k ovládacím prvkům v řešeních pro systém Office.

K vytvoření objektu ListObject, který je vázán k instanci objektu dataset

  1. V Zdroje dat okno, rozbalte AdventureWorksLTDataSet uzlu AdventureWorksDataSet.

  2. Vyberte výrobku uzel, klepněte na šipku rozevíracího seznamu, který se zobrazí a zvolte objektu ListObject v rozevíracím seznamu.

    Je-li na šipku rozevíracího seznamu nezobrazí, potvrďte, že sešit je otevřen v návrháři.

  3. Přetáhněte výrobku tabulku do buňky A1.

    A ListObject ovládací prvek s názvem productListObject je vytvořen na listu s počátkem v buňce A1.Současně, objekt dataset s názvem adventureWorksLTDataSet a BindingSource s názvem productBindingSource jsou přidány do projektu.ListObject Je vázán BindingSource, který je zase vázán na objekt dataset.

Přidání datové sady do mezipaměti Data

Chcete-li kód mimo projekt sešitu aplikace Excel pro přístup k objektu dataset v sešitu, je nutné přidat datové sady do mezipaměti data.Další informace o mezipaměti dat naleznete v tématu Data uložená v mezipaměti v přizpůsobeních na úrovni dokumentu a Ukládaní dat do mezipaměti.

Chcete-li přidat objekt dataset do mezipaměti data

  1. V návrháři, klepněte na tlačítko adventureWorksLTDataSet.

  2. V Vlastnosti okno, nastavit Modifikátory vlastnost veřejné.

  3. Nastavit CacheInDocument vlastnost True.

Checkpoint

Sestavte a spusťte projekt sešitu aplikace Excel k zajištění toho, že sestavuje a spouští bez chyb.

Chcete-li sestavit a spustit projekt

  1. V Průzkumníku, klepněte pravým tlačítkem myši AdventureWorksReport projektu, zvolte laděnía potom klepněte na tlačítko Spustit novou instanci.

    Sestavení projektu a otevře sešit v aplikaci Excel.ListObject v listu List1 je prázdná, protože adventureWorksLTDataSet objekt v mezipaměti dat ještě žádná data.V další části, použije aplikace konzoly k naplnění adventureWorksLTDataSet objekt s daty.

  2. Ukončete aplikaci Excel.Změny nelze uložit.

Vytvoření projektu aplikace konzoly

Vytvořte projekt konzolové aplikace použít k vložení dat v datové sady v mezipaměti v sešitu.

Vytvořte projekt konzolové aplikace

  1. V Průzkumníku, klepněte pravým tlačítkem myši AdventureWorksDataSet řešení, přejděte na příkaz Přidata potom klepněte na tlačítko Nový projekt.

  2. V Typy projektů podokně rozbalte Visual C# nebo jazyka Visual Basica potom klepněte na tlačítko Windows.

  3. V šablony podokně, vyberte Aplikace konzoly.

  4. V jméno zadejte DataWriter.Neupravujte umístění.

  5. Klikněte na tlačítko OK.

    Visual StudioPřidá DataWriter projektu na Průzkumníku a otevře Program.cs nebo Module1.vb soubor kódu.

Přidání dat do mezipaměti objektu Dataset pomocí konzolové aplikace

Použití ServerDocument tříd v aplikaci konzoly k vyplnění datové sady v mezipaměti v sešitu s daty.

Chcete-li přidat data do mezipaměti objektu dataset

  1. V Průzkumníku, klepněte pravým tlačítkem myši DataWriter projektu a klepněte na tlačítko Přidat odkaz na.

  2. Na .NET kartu, vyberte Microsoft.VisualStudio.Tools.Applications.ServerDocument.

  3. Klikněte na tlačítko OK.

  4. V Průzkumníku, klepněte pravým tlačítkem myši DataWriter projektu a klepněte na tlačítko Přidat odkaz na.

  5. Na projekty kartu, vyberte AdventureWorksDataSeta klepněte na tlačítko OK.

  6. Otevřete soubor Program.cs nebo Module1.vb v editoru kódu.

  7. Přidejte následující using (pro jazyk C#) nebo Imports (pro jazyk Visual Basic) příkaz na začátek souboru kódu.

    Imports Microsoft.VisualStudio.Tools.Applications
    
    using Microsoft.VisualStudio.Tools.Applications;
    
  8. Do metody Main přidejte následující kód:Tento kód deklaruje následující objekty:

    • Instance AdventureWorksLTDataSet a ProductTableAdapter typy, které jsou definovány v AdventureWorksDataSet projektu.

    • Cesta k sešitu AdventureWorksReport ve složce sestavení AdventureWorksReport projektu.

    • A ServerDocument objekt, který chcete použít pro přístup k mezipaměti data v sešitu.

      [!POZNÁMKA]

      Následující kód předpokládá, že používáte sešit, který má příponu XLSX.Je-li sešit ve vašem projektu má jinou příponu souboru, změňte cestu podle potřeby.

    Dim productDataSet As New AdventureWorksDataSet.AdventureWorksLTDataSet()
    Dim productTableAdapter As _
        New AdventureWorksDataSet.AdventureWorksLTDataSetTableAdapters.ProductTableAdapter()
    
    Dim workbookPath As String = System.Environment.GetFolderPath( _
        Environment.SpecialFolder.MyDocuments) & _
        "\AdventureWorksReport\bin\Debug\AdventureWorksReport.xlsx" 
    Dim serverDocument1 As ServerDocument = Nothing
    
    AdventureWorksDataSet.AdventureWorksLTDataSet productDataSet = 
        new AdventureWorksDataSet.AdventureWorksLTDataSet();
    AdventureWorksDataSet.AdventureWorksLTDataSetTableAdapters.ProductTableAdapter productTableAdapter =
        new AdventureWorksDataSet.AdventureWorksLTDataSetTableAdapters.ProductTableAdapter();
    
    string workbookPath = System.Environment.GetFolderPath(
        Environment.SpecialFolder.MyDocuments) +
        @"\AdventureWorksReport\bin\Debug\AdventureWorksReport.xlsx";
    ServerDocument serverDocument1 = null;
    
  9. Přidejte následující kód, který Main metoda po kódu, který jste přidali v předchozím kroku.Tento kód provede následující úlohy:

    • Objekt typu dataset vyplní pomocí adaptéru tabulky.

    • Používá CachedData vlastnost ServerDocument třídu pro přístup k datové sady v mezipaměti v sešitu.

    • Používá SerializeDataInstance metodu k vyplnění mezipaměti objektu dataset s daty z místní definované datové sady.

    Try
        productTableAdapter.Fill(productDataSet.Product)
        Console.WriteLine("The local dataset is filled.")
    
        serverDocument1 = New ServerDocument(workbookPath)
        Dim dataHostItem1 As CachedDataHostItem = _
            serverDocument1.CachedData.HostItems("AdventureWorksReport.Sheet1")
        Dim dataItem1 As CachedDataItem = dataHostItem1.CachedData("AdventureWorksLTDataSet")
    
        ' Initialize the worksheet dataset with the local dataset. 
        If dataItem1 IsNot Nothing Then
            dataItem1.SerializeDataInstance(productDataSet)
            serverDocument1.Save()
            Console.WriteLine("The data is saved to the data cache.")
        Else
            Console.WriteLine("The data object is not found in the data cache.")
        End If 
    Catch ex As System.Data.SqlClient.SqlException
        Console.WriteLine(ex.Message)
    Catch ex As System.IO.FileNotFoundException
        Console.WriteLine("The specified workbook does not exist.")
    Finally 
        If Not (serverDocument1 Is Nothing) Then
            serverDocument1.Close()
        End If
        Console.WriteLine(vbLf & vbLf & "Press Enter to close the application.")
        Console.ReadLine()
    End Try
    
    try
    {
        productTableAdapter.Fill(productDataSet.Product);
        Console.WriteLine("The local dataset is filled.");
    
        serverDocument1 = new ServerDocument(workbookPath);
        CachedDataHostItem dataHostItem1 =
            serverDocument1.CachedData.HostItems["AdventureWorksReport.Sheet1"];
        CachedDataItem dataItem1 = dataHostItem1.CachedData["adventureWorksLTDataSet"];
    
        // Initialize the worksheet dataset with the local dataset. 
        if (dataItem1 != null)
        {
            dataItem1.SerializeDataInstance(productDataSet);
            serverDocument1.Save();
            Console.WriteLine("The data is saved to the data cache.");
            Console.ReadLine();
        }
        else
        {
            Console.WriteLine("The data object is not found in the data cache.");
        }
    }
    catch (System.Data.SqlClient.SqlException ex)
    {
        Console.WriteLine(ex.Message);
    }
    catch (System.IO.FileNotFoundException)
    {
        Console.WriteLine("The specified workbook does not exist.");
    }
    finally
    {
        if (serverDocument1 != null)
        {
            serverDocument1.Close();
        }
    
        Console.WriteLine("\n\nPress Enter to close the application.");
        Console.ReadLine();
    }
    
  10. V Průzkumníku, klepněte pravým tlačítkem myši DataWriter projektu, přejděte na příkaz laděnía potom klepněte na tlačítko Spustit novou instanci.

    Sestavení projektu a aplikace konzoly zobrazí několik zpráv o stavu při zaplnění místní dataset, a pokud aplikace ukládá data do mezipaměti objektu dataset v sešitu.Stisknutím klávesy ENTER ukončete aplikaci.

Testování sešitu

Při otevření sešitu, ListObject nyní zobrazuje data, která byla přidána do mezipaměti objektu dataset pomocí konzolové aplikace.

Chcete-li otestovat sešitu

  1. Pokud je stále otevřen, zavřete sešit AdventureWorksReport v návrháři Visual Studio.

  2. V okně Průzkumník souborů otevřít sešit AdventureWorksReport, který je ve složce sestavení AdventureWorksReport projektu.Ve výchozím nastavení je složka sestavení v následujících umístěních:

    • %USERPROFILE%\My Documents\AdventureWorksReport\bin\Debug (pro systém Windows XP a starší)

    • %USERPROFILE%\Documents\AdventureWorksReport\bin\Debug (pro systém Windows Vista)

  3. Ověřte, zda ListObject je naplněn daty po otevření sešitu.

Další kroky

Další informace o práci s daty v mezipaměti z těchto témat:

Viz také

Úkoly

Návod: Změna dat uložených v mezipaměti sešitu na serveru

Koncepty

Připojení k datům v aplikacích Windows Forms