TableResult GetTable(OdId tOb, GetTableArg tArg)
tOb. Моникёр объекта репозитория, являющегося таблицей, присоединённой таблицой или представлением.
tArg. Параметры выполнения операции.
Операция GetTable извлекает метаданные таблицы/присоединённой таблицы/представления.
Операция позволяет получить информацию о структуре таблицы/присоединённой таблицы/представления, а также о наборе данных, хранящихся в этих объектах. Для выполнения операции укажите в поле tOb моникёр открытого экземпляра объекта, а в поле tArg параметры извлечения метаданных. Моникёр может быть получен при выполнении операции OpenTable. Результатом операции будут запрошенные метаданные.
Пример получения информации о физическом имени, полях, которые созданы в таблице, а также о наборе данных, который в ней хранится. В запросе передается моникёр открытого экземпляра таблицы и шаблон, указывающий необходимость получить данную информацию. В ответе приходит запрошенная информация.
{
"GetTable" :
{
"tOb" :
{
"id" : "S1!M!S!TABLE5"
},
"tArg" :
{
"pattern" :
{
"obInst" : "true",
"nativName" : "true",
"fields" : "Get",
"rows" : "Get"
}
}
}
}
{
"GetTableResult" :
{
"id" :
{
"id" : "S1!M!S!TABLE5"
},
"meta" :
{
"obInst" :
{
"obDesc" :
{
"@ds" : "",
"@isShortcut" : "0",
"@isLink" : "0",
"@ver" : "20",
"@hf" : "0",
"i" : "T_COUNTRY_INFO",
"n" : "Данные по странам",
"k" : "9053",
"c" : "769",
"p" : "9050",
"h" : "0",
"hasPrv" : "0",
"ic" : "0",
"isPermanent" : "1",
"isTemp" : "0"
},
"openArgs" : ""
},
"nativName" : "T_COUNTRY",
"fields" :
{
"its" :
{
"it" :
[
{
"k" : "1",
"id" : "ISO_CODE",
"n" : "ISO код страны",
"vis" : "1",
"dt" : "1",
"mandatory" : "1",
"defaultValue" : "",
"size" : "255",
"precision" : "0",
"isCalculated" : "0"
},
{
"k" : "2",
"id" : "NAME",
"n" : "Наименование",
"vis" : "1",
"dt" : "1",
"mandatory" : "1",
"defaultValue" : "",
"size" : "255",
"precision" : "0",
"isCalculated" : "0"
},
{
"k" : "3",
"id" : "POPULATION",
"n" : "Население",
"vis" : "1",
"dt" : "3",
"mandatory" : "0",
"defaultValue" : "",
"size" : "20",
"precision" : "2",
"isCalculated" : "0"
},
{
"k" : "4",
"id" : "AREA",
"n" : "Площадь",
"vis" : "1",
"dt" : "3",
"mandatory" : "0",
"defaultValue" : "",
"size" : "20",
"precision" : "2",
"isCalculated" : "0"
},
{
"k" : "5",
"id" : "CURRENCY",
"n" : "Валюта",
"vis" : "1",
"dt" : "1",
"mandatory" : "0",
"defaultValue" : "",
"size" : "255",
"precision" : "0",
"isCalculated" : "0"
}
]
}
},
"rows" :
{
"its" :
{
"r" :
[
{
"it" :
[
"RU",
"Russia",
"143666931",
"17125187",
"Russian ruble (RUB)"
]
},
{
"it" :
[
"US",
"United States of America",
"320194478",
"9519431",
"United States dollar ($) (USD)"
]
}
]
}
}
}
}
}
public static TableResult GetTableMetadata(string moniker)
{
var somClient = new SomPortTypeClient(); //Прокси-объект для выполнения операций
//Параметры выполнения операции
var tGet = new GetTable()
{
tArg = new GetTableArg()
{
pattern = new TableMdPattern
{
fields = ListOperation.Get,
nativName = true,
rows = ListOperation.Get
}
},
tOb = new OdId() { id = moniker }
};
//Получение метаданных
var tResult = somClient.GetTable(tGet);
return tResult;
}
См. также: