[方法] エンティティに対して SpecificFinder メソッドを実行する
SpecificFinder は、与えられたキー (一意の ID) が 1 つの エンティティ インスタンスを返す特別なメソッドです。たとえば、Customer エンティティに対して、SpecificFinder メソッドは次のようになる可能性があります。
SELECT * FROM Customers where ID=1
ここでは、ビジネス データ カタログに登録されているエンティティに対して SpecificFinder メソッドを実行する方法を示します。
例
この例は、AdventureWorks2000 サンプルで Product エンティティに対して SpecificFinder メソッドを実行する方法を示しています。
前提条件
共有サービス プロバイダが既に作成されていることを確認します。
コード内の定数値 EnterYourSSPNameHere を共有リソース プロバイダの名前に置き換えます。
例で参照されている LobSystem およびエンティティ名がビジネス データ カタログに存在することを確認します。有効な名前を使用します。
プロジェクト参照
このサンプルを実行する前に、コンソール アプリケーション コード プロジェクトに以下のプロジェクト参照を追加します。
Microsoft.SharePoint
Microsoft.SharePoint.Portal
Microsoft.Office.Server
using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using Microsoft.Office.Server.ApplicationRegistry.MetadataModel;
using Microsoft.Office.Server.ApplicationRegistry.Runtime;
using Microsoft.Office.Server.ApplicationRegistry.SystemSpecific;
using Microsoft.Office.Server.ApplicationRegistry.Infrastructure;
using WSSAdmin = Microsoft.SharePoint.Administration;
using OSSAdmin = Microsoft.Office.Server.Administration;
namespace Microsoft.SDK.SharePointServer.Samples
{
class ExecuteSpecificFinder
{
const string yourSSPName ="EnterYourSSPNameHere";
static void Main(string[] args)
{
SetupBDC();
FindSpecific();
Console.WriteLine("Press any key to exit...");
Console.Read();
}
static void SetupBDC()
{
SqlSessionProvider.Instance().SetSharedResourceProviderToUse(yourSSPName);
}
static void FindSpecific()
{
NamedLobSystemInstanceDictionary sysInstances = ApplicationRegistry.GetLobSystemInstances();
LobSystemInstance AdvWorksIns = sysInstances["AdventureWorksSampleInstance"];
Entity prodEntity = AdvWorksIns.GetEntities()["Product"];
//ProductID = 1
IEntityInstance IE = prodEntity.FindSpecific(1, AdvWorksIns);
foreach (Field f in prodEntity.GetSpecificFinderView().Fields)
Console.Write(IE[f]);
Console.WriteLine("");
}
}
}