Extrait de code : exécuter l’instance de méthode Creator d’un type de contenu externe
Dernière modification : jeudi 6 mai 2010
S’applique à : SharePoint Server 2010
Dans cet article
Description
Conditions préalables requises
Pour utiliser cet exemple
Description
L’exemple de code suivant montre comment exécuter par programmation une instance de méthode Creator d’un type de contenu externe, à l’aide du modèle objet de runtime BDC sur le serveur.
Conditions préalables requises
Microsoft SharePoint Server 2010 ou Microsoft SharePoint Foundation 2010 sur le serveur
Microsoft .NET Framework 3.5 sur l’ordinateur client
Microsoft Visual Studio
Au moins un type de contenu externe inscrit dans le magasin de métadonnées BDC
Pour utiliser cet exemple
Démarrez Visual Studio et créez un projet d’application console C#. Sélectionner .NET Framework 3.5 lorsque vous créez le projet.
Dans le menu Affichage, cliquez sur Pages des propriétés pour afficher les propriétés du projet.
Sous l’onglet Générer, pour Plateforme cible, sélectionnez Any CPU.
Fermez la fenêtre des propriétés du projet.
Dans l’Explorateur de solutions, sous Références, supprimez toutes les références du projet à l’exception de System et System.Core.
Ajoutez les références suivantes au projet :
Microsoft.BusinessData
Microsoft.SharePoint
System.Web
Remplacez le code généré automatiquement dans Program.cs par le code fourni à la fin de cette procédure.
Remplacez les valeurs correspondant à <SiteUrl>, <nameSpace> et <entityName> par des valeurs valides.
Enregistrez le projet.
Compilez et exécutez le projet.
using System;
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)
{
BDCCreate();
}
//How To: Create an External Content Type
public static void BDCCreate()
{
//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;
IView createView = entity.GetCreatorView("Create");
IFieldValueDictionary fieldValueDictionary =
createView.GetDefaultValues();
// The following will work only for Sales.Customer table in AdventureWorks2008
//Enter number of Customers To Create
Console.Write("\nEnter number of Customers To Create : ");
int number = int.Parse(Console.ReadLine());
// Code below can be used to edit the values and create Records.
for (int i = 1; i <= number; i++)
{
// Example values for TerritoryID : 1,2,4
Console.Write("\nEnter the TerritoryID : ");
fieldValueDictionary["TerritoryID"] = int.Parse(Console.ReadLine());
// Example value CustomerType : S
Console.Write("\nEnter the CustomerType : ");
fieldValueDictionary["CustomerType"] = Console.ReadLine();
fieldValueDictionary["rowguid"] = Guid.NewGuid();
fieldValueDictionary["ModifiedDate"] = DateTime.Now;
Identity id = entity.Create(fieldValueDictionary, LobSysteminstance);
Console.WriteLine("Successfully Inserted Item Number: {0}", i);
}
}
Console.WriteLine("Press any key to continue...");
Console.ReadKey();
}
}
}
}