Fragmento de código: ejecución de una instancia del método Finder 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 Finder 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 Visual Studio en el cliente.
Al menos un tipo de contenido externo registrado en el Repositorio de metadatos de BDC.
Para usar este ejemplo
Inicie Visual Studio y, a continuación, cree un proyecto de aplicación de consola de 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.
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 de Program.cs por el código que aparece al final de este procedimiento.
Reemplace los valores de <siteUrl>, <nameSpace> y <entityName> por valores válidos.
Guarde el proyecto.
Compile y ejecute el proyecto.
using System;
using Microsoft.BusinessData.Runtime;
using Microsoft.SharePoint;
using Microsoft.SharePoint.BusinessData.SharedService;
using Microsoft.SharePoint.Administration;
using Microsoft.BusinessData.MetadataModel;
using Microsoft.BusinessData.MetadataModel.Collections;
namespace SDKSamples
{
class Methods
{
static void Main(string[] args)
{
BDCGetAllFieldsAndRecords();
}
// Get the fields and read data from an external content type.
public static void BDCGetAllFieldsAndRecords()
{
// Specify the SiteURL, Namespace, and the Entity Name.
string SiteURL = "<siteUrl>";
string nameSpace = "<nameSpace>";
string entityName = "<entityName>";
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);
IEntity entity = catalog.GetEntity(
nameSpace, entityName);
ILobSystemInstance LobSysteminstance =
entity.GetLobSystem().
GetLobSystemInstances()[0].Value;
// Display the fields in the Entity.
IFieldCollection fieldCollection =
entity.GetFinderView("Read List").Fields;
foreach (IField field in fieldCollection)
{
Console.Write(field.Name.PadRight(20));
}
Console.WriteLine();
// Display all the records in the Entity.
IMethodInstance methodInstance = entity.GetMethodInstance(
"Read List", MethodInstanceType.Finder);
IEntityInstanceEnumerator ientityInstanceEnumerator =
entity.FindFiltered(
methodInstance.GetFilters(), LobSysteminstance);
while (ientityInstanceEnumerator.MoveNext())
{
foreach (IField field in fieldCollection)
{
Console.Write(
ientityInstanceEnumerator.
Current[field.Name].ToString().PadRight(20));
}
Console.WriteLine();
}
}
Console.ReadKey();
}
}
}
}
Vea también
Referencia
GetDatabaseBackedMetadataCatalog(SPServiceContext)
GetMethodInstance(String, MethodInstanceType)