QueryResult SetQuery(OdId tOb, SetQueryArg tArg)
tOb. Моникёр объекта репозитория, являющегося запросом.
tArg. Параметры выполнения операции.
Операция SetQuery изменяет объект репозитория «Запрос».
Операция позволяет изменить текст SQL-запроса и его параметры. Запрос должен быть открыт на редактирование. Для выполнения операции укажите в поле tOb моникёр открытого экземпляра запроса, а в поле tArg.meta обновлённые метаданных, которые необходимо применить. Моникёр может быть получен при выполнении операции OpenQuery. В поле tArg.pattern укажите шаблон, в соответствии с которым будут изменяться метаданные. Если определено поле tArg.metaGet, то результатом операции будут обновлённые метаданные, которые будут повторно получены после их изменения в объекте. Сохранение изменений осуществляется автоматически при выполнении операции.
Пример изменения SQL-запроса в объекте «Запрос». В запросе передаётя моникёр открытого экземпляра объекта и новый SQL-запрос. В ответе приходит список полей и набор данных, которые получены при выполнении нового SQL-запроса.
{
"SetQuery" :
{
"tOb" :
{
"id" : "S1!M!S!QUERY6"
},
"tArg" :
{
"pattern" :
{
"obInst" : "true",
"sqlText" : "true"
},
"meta" :
{
"sqlText" :
{
"value" : "SELECT * FROM T_SOURCE"
}
},
"metaGet" :
{
"obInst" : "true",
"fields" : "true",
"rows" : "Get"
}
}
}
}
{
"SetQueryResult" :
{
"id" :
{
"id" : "S1!M!S!QUERY6"
},
"meta" :
{
"obInst" :
{
"obDesc" :
{
"@ds" : "",
"@isShortcut" : "0",
"@isLink" : "0",
"@ver" : "9",
"@hf" : "0",
"i" : "T_QUERY",
"n" : "Запрос",
"k" : "9051",
"c" : "770",
"p" : "9050",
"h" : "0",
"hasPrv" : "0",
"ic" : "0",
"isPermanent" : "1",
"isTemp" : "0"
},
"openArgs" : ""
},
"fields" :
{
"its" :
{
"it" :
[
"ISO_CODE",
"NAME",
"POPULATION",
"AREA",
"CURRENCY"
]
}
},
"rows" :
{
"its" :
{
"r" :
[
{
"it" :
[
"",
"Данные госкомстата",
"",
"",
"",
"1",
"2"
]
},
{
"it" :
[
"",
"Данные департамента МЭРТ РФ",
"",
"",
"",
"2",
"3"
]
},
{
"it" :
[
"",
"Прогноз департаментов (2-ой вариант)",
"",
"",
"",
"3",
"5"
]
},
{
"it" :
[
"",
"Данные регионов",
"",
"",
"",
"4",
"4"
]
}
]
}
}
}
}
}
public static QueryResult ChangeQuery(string moniker, string newSQLText)
{
var somClient = new SomPortTypeClient(); //Прокси-объект для выполнения операций
//Параметры выполнения операции
var tSet = new SetQuery()
{
tArg = new SetQueryArg()
{
meta = new QueryMd()
{
sqlText = new QuerySqlText() { value = newSQLText }
},
pattern = new QueryMdPattern
{
sqlText = true,
},
metaGet = new QueryMdPattern
{
fields = true,
rows = ListOperation.Get
}
},
tOb = new OdId() { id = moniker }
};
//Изменение метаданных
var tResult = somClient.SetQuery(tSet);
return tResult;
}
См. также: