Я использую System.Data.OracleClient
, который выполняет привязку параметров по имени и проверяет синхронизацию CommandText и Parameters:
public string CommandText { get; set; }
public IEnumerable<OracleParameter> Parameters { get; set; }
private void VerifyThatAllParametersAreBound()
{
var variableNames = Regex.Matches(CommandText, ":\\w+")
.Cast<Match>().Select(m => m.Value).ToArray();
var parameteterNames = Parameters.Select(p => p.ParameterName).ToArray();
var unboundVariables = variableNames.Except(parameteterNames).ToArray();
if (unboundVariables.Length > 0)
{
throw new Exception("Variable in CommandText missing parameter: "
+ string.Join(", ", unboundVariables) + ".");
}
var unboundParameters = parameteterNames.Except(variableNames).ToArray();
if (unboundParameters.Length > 0)
{
throw new Exception("Parameter that is not used in CommandText: "
+ string.Join(", ", unboundParameters) + ".");
}
}
Еще один запрос выбрасывает ORA-01008: not all variables bound
. При ручной вставке значений параметров в ошибочный CommandText выполняется запрос, поэтому значения CommandText и Parameters должны быть в порядке. Я использую: в качестве префикса для переменных и имен параметров, и он работает для других запросов.
Как я могу определить причину этого исключения?