Fragmento de código: ejecución de la instancia de método BulkSpecificFinder de un tipo de contenido externo
Última modificación: jueves, 06 de mayo de 2010
Hace referencia a: SharePoint Server 2010
En este artículo
Descripción
Requisitos previos
Para usar este ejemplo
Descripción
En el siguiente ejemplo de código se muestra cómo ejecutar mediante programación una instancia de método BulkSpecificFinder de un tipo de contenido externo con el modelo de objetos de tiempo de ejecución de BDC en el servidor.
Requisitos previos
Microsoft SharePoint Server 2010 o Microsoft SharePoint Foundation 2010 en el servidor.
Microsoft .NET Framework 3.5 y Microsoft Visual Studio en el cliente.
Para usar este ejemplo
Inicie Visual Studio y cree un proyecto de aplicación de consola C#. Seleccione .NET Framework 3.5 al crear el proyecto.
En el menú Ver, haga clic en Páginas de propiedades para que aparezcan las propiedades del proyecto.
En la ficha Compilación, para el Destino de la plataforma, seleccione Cualquier CPU.
Cierre la ventana de propiedades del proyecto.
En el Explorador de soluciones, en Referencias, quite todas las referencias del proyecto excepto System y System.Core.
Agregue las siguientes referencias al proyecto:
Microsoft.BusinessData
Microsoft.SharePoint
System.Web
Reemplace el código generado automáticamente en Program.cs por el código que aparece al final de este procedimiento.
Reemplace los valores <ID> y el valor SiteURL por valores válidos.
Este ejemplo se basa en la base de datos de ejemplo AdventureWorks y el tipo de contenido externo SalesOrder. Si el sistema externo es diferente, cambie el nombre del tipo de contenido externo y LobSystem según corresponda en el código.
Guarde el proyecto.
Compile y ejecute el proyecto.
using System;
using System.Collections.Generic;
using Microsoft.SharePoint.BusinessData.SharedService;
using Microsoft.BusinessData.MetadataModel;
using Microsoft.BusinessData.MetadataModel.Collections;
using Microsoft.BusinessData.Runtime;
using Microsoft.SharePoint.Administration;
using Microsoft.SharePoint;
namespace SDKSamples
{
class Methods
{
static void Main(string[] args)
{
List<Identity> identities = new List<Identity>();
identities.Add(new Identity(<ID1>));
identities.Add(new Identity(<ID2>));
identities.Add(new Identity(<ID3>));
identities.Add(new Identity(<ID4>));
FindMultipleSalesOrderById(identities);
}
// BulkSpecificFinder.
public static void FindMultipleSalesOrderById(
IList<Identity> identities)
{
string SiteURL = "<siteUrl>";
using (SPSite site = new SPSite(SiteURL))
{
using (new Microsoft.SharePoint.SPServiceContextScope(
SPServiceContext.GetContext(site)))
{
BdcService service =
SPFarm.Local.Services.GetValue<BdcService>(String.Empty);
IMetadataCatalog catalog =
service.GetDatabaseBackedMetadataCatalog(
SPServiceContext.Current);
// Get entity.
IEntity salesOrderEntity = catalog.GetEntity(
"AdventureWorks", "SalesOrder");
// Get LOB System instance.
ILobSystemInstance lobSystemInstance =
salesOrderEntity.GetLobSystem().
GetLobSystemInstances()["AdventureWorks"];
IEntityInstanceEnumerator orders = null;
try
{
// Read the given identities.
orders = salesOrderEntity.FindSpecificMultiple(
identities,
"Bulk Read Item",
lobSystemInstance,
OperationMode.Online);
// List found orders.
while (orders.MoveNext())
{
Console.WriteLine(
String.Format(
"Id: {0}, OrderDate: {1}",
orders.Current["SalesOrderID"],
orders.Current["OrderDate"]));
}
}
finally
{
// Ensure the enumerator is closed.
if (orders != null)
{
orders.Close();
}
}
}
}
}
}
}
Vea también
Referencia
GetDatabaseBackedMetadataCatalog(SPServiceContext)
FindSpecificMultiple(IList<Identity>, String, ILobSystemInstance, OperationMode)