DatabaseResult OpenDatabase(OdId tOb, OpenDatabaseArg tArg)
tOb. Моникёр объекта репозитория, являющегося базой данных.
tArg. Параметры выполнения операции.
Операция OpenDatabase открывает базу данных и возвращает контекст для работы с ней.
Операция позволяет получить доступ к настройкам подключения базы данных и получить список таблиц, которые в ней созданы. Для выполнения операции укажите в поле tOb моникёр объекта репозитория, являющегося базой данных, а в поле tArg параметры открытия базы данных. Параметры для извлечения метаданных указываются в поле tArg.metaGet. Результатом работы операции будет моникёр открытого экземпляра базы данных, а также запрошенные метаданные, если при выполнении операции был задан соответствующий шаблон. Дальнейшая работа с открытым экземпляром базы данных осуществляется с помощью операций GetDatabase и SetDatabase. Для закрытия открытого экземпляра базы данных используйте операцию CloseDatabase.
Пример открытия базы данных на редактирование. В запросе передается моникёр базы данных в репозитории. В ответе приходит моникёр открытого экземпляра базы данных.
В примере для C# используется функция FindObjectById, код которой приведён в примере «Получение описания объекта по его идентификатору».
{
"OpenDatabase" :
{
"tOb" :
{
"id" : "S1!M!174189"
},
"tArg" :
{
"args" :
{
"openForEdit" : "true"
}
}
}
}
{
"OpenDatabaseResult" :
{
"id" :
{
"id" : "S1!M!S!DB4"
}
}
}
public static DatabaseResult OpenDB(MbId mb, string id)
{
var somClient = new SomPortTypeClient(); //Прокси-объект для выполнения операций
//Параметры выполнения операции
var tOpen = new OpenDatabase()
{
tArg = new OpenDatabaseArg()
{
args = new DatabaseOpenArgs()
{
openForEdit = true
}
},
tOb = new OdId() { id = mb.id + "!" + FindObjectById(mb, id).k }
};
//Открытие базы данных
var tResult = somClient.OpenDatabase(tOpen);
return tResult;
}
См. также: