我有一个执行一些SQL命令的函数,我创建了一个记录器,我在文件中写入了执行的命令和受影响的行数,但我还需要记下命令可能已经引发了OracleException,所以我已经完成了这段代码:
public string ExecuteCommand(List<string> comandos)
{
var excepção = string.Empty;
var executar = new OracleCommand
{
Connection = Updater.OraConnection,
CommandType = CommandType.Text
};
try
{
Logg("Inicio da execução de comandos");
foreach (var variable in comandos)
{
excepção = variable;
executar.CommandText = variable;
throw new OracleException(0, "comando", "stuff", "adasds");
var Afectados = executar.ExecuteNonQuery();
Logg(variable);
Logg("Linhas afectadas: " + Afectados);
}
}
catch (OracleException)
{
Logg("Erros:");
Logg(excepção);
return excepção;
}
return excepção;
}
我试图在任何地方进行搜索,但是我无法找到任何合适的甚至是有针对性的答案,所以我很遗憾因为我无法提出oracleException,因为我这样做:throw new OracleException(0, "comando", "stuff", "adasds");
它只是说由于其保护级别,无法在此访问构造函数。 任何帮助都是aprecciated
答案 0 :(得分:0)
public class OracleException : Exception
{
}
该类需要将其范围设置为public或internal。无法将构造函数作为私有类进行访问。
答案 1 :(得分:0)
如果您只是想模拟抛出的异常而不关心询问对象那么。
private OracleResilienceManager CreateSut()
{
return new OracleResilienceManager(_resilienceSettings);
}
throw System.Runtime.Serialization.CreateSafeUninitializedProtectedType<OracleException>();
在我的情况下,我正在测试重试策略,并希望在抛出此异常时测试重试逻辑。不需要访问对象本身。