Codeausschnitt: Abrufen von "DatabaseBackedMetadataCatalog" auf dem Server
Letzte Änderung: Mittwoch, 5. Mai 2010
Gilt für: SharePoint Server 2010
Inhalt dieses Artikels
Beschreibung
Voraussetzungen
So verwenden Sie dieses Beispiel
Beschreibung
Im folgenden Codebeispiel wird veranschaulicht, wie DatabaseBackedMetadataCatalog auf dem Server mithilfe des Business Data Connectivity-Dienst (BDC)-Laufzeitobjektmodells auf dem Server abgerufen wird.
Voraussetzungen
Installation von Microsoft SharePoint Server 2010 oder Microsoft SharePoint Foundation 2010 auf dem Server
Microsoft .NET Framework 3.5 und Microsoft Visual Studio
Mindestens ein registrierter externer Inhaltstyp im Metadatenspeicher von BDC
So verwenden Sie dieses Beispiel
Starten Sie Visual Studio, und erstellen Sie ein neues C#-Konsolenanwendungsprojekt. Wählen Sie beim Erstellen des Projekts .NET Framework 3.5 aus.
Wählen Sie im Menü Ansicht den Befehl Eigenschaftenseiten aus, um die Projekteigenschaften aufzurufen.
Wählen Sie auf der Registerkarte Erstellen unter Zielplattform die Option Any CPU aus.
Schließen Sie das Fenster mit den Projekteigenschaften.
Entfernen Sie im Projektmappen-Explorer unter Verweise sämtliche Projektverweise bis auf System und System.Core.
Fügen Sie dem Projekt die folgenden Verweise hinzu:
Microsoft.BusinessData (aus SharePoint_RootFolder\ISAPI)
Microsoft.SharePoint
Ersetzen Sie den automatisch generierten Code in Program.cs durch den Code am Ende dieser Prozedur.
Ersetzen Sie die Platzhalterwerte von <siteUrl>, <nameSpace>, <lobsystemInstance> und <entityName> durch gültige Werte.
Speichern Sie das Projekt.
Kompilieren Sie das Projekt.
Führen Sie die Anwendung auf dem Servercomputer aus, auf dem SharePoint Server 2010 oder SharePoint Foundation 2010 installiert ist.
using Microsoft.BusinessData.MetadataModel;
using Microsoft.BusinessData.Runtime;
using Microsoft.SharePoint.BusinessData.MetadataModel;
using Microsoft.SharePoint;
using Microsoft.SharePoint.BusinessData.SharedService;
//Code.
// Get context from specific site.
SPServiceContext context = SPServiceContext.GetContext(new SPSite("<siteUrl>"));
IMetadataCatalog databaseCatalog = null;
BdcService bdcService = SPFarm.Local.Services.GetValue<BdcService>(String.Empty);
if (null != bdcService)
{
databaseCatalog = bdcService.GetDatabaseBackedMetadataCatalog(context);
}
string @namespace = "<nameSpace>";
string entityName = "<entityName>";
string lsiName = "<lobsystemInstance>";
IEntity entity = databaseCatalog.GetEntity(@namespace, entityName);
ILobSystem lobSystem = entity.GetLobSystem();
ILobSystemInstance lsi = lobSystem.GetLobSystemInstances()[lsiName];