SQLの左結合に相当するArcObjectsコードが必要です。
例:以下のSQLコードがありChecklistId
ます。値に基づいて両方のテーブルからレコードをフェッチするのは簡単な結合です。
SELECT T1.ChecklistId, T1.ChecklistName,
T2.Latitude, T2.Longitude
FROM [dbo].[TableOne] T1
INNER JOIN [dbo].[TableTwo] T2 ON T2.ChecklistId = T1.ChecklistId
WHERE T1.ChecklistId = @ChecklistId
上記のSQLクエリをArcObjectsに変換しました。
IQueryDef queryDef = featureWorkspace.CreateQueryDef();
queryDef.Tables = "TableOne, TableTwo";
queryDef.SubFields = "TableOne.ChecklistId, TableOne.ChecklistName, TableTwo.Latitude, TableTwo.Longitude";
queryDef.WhereClause = "TableOne.ChecklistId = '" + checklistId + "' AND TableOne.ChecklistId = TableTwo.ChecklistId";
ICursor cursor = queryDef.Evaluate();
IRow row = null;
while ((row = cursor.NextRow()) != null)
{
// ... get and set the values to the objects
}
値T1.ChecklistOwner
を持つ列でもレコードをフェッチしたいnull
。簡単に言えばLEFT JOIN
、次のようにSQLと言うことができます。
SELECT T1.ChecklistId, T1.ChecklistName,
T2.Latitude, T2.Longitude,
T3.FullName
FROM [dbo].[TableOne] T1
INNER JOIN [dbo].[TableTwo] T2 ON T2.ChecklistId = T1.ChecklistId
LEFT JOIN [dbo].[TableThree] T3 ON T3.UserAlias = T1.ChecklistOwner
WHERE T1.ChecklistId = @ChecklistId
上記のSQLクエリをArcObjectsに変換するにはどうすればよいですか?