ODP.NET 之 ExecuteNoQuery 执行 Merge into 返回值
当执行Oracle.ManagedDataAccess.Client.OracleCommand.ExecuteNonQuery时,如果sql语句是 merge into ...,则返回值表现不稳定,大概率是-1,而不是语句的影响行数。在我的开发环境下debug,返回的是语句影响的行数。但一发布到正式环境下,就返回-1。鉴于此,在有需要返回语种的执行行数,且语句是merge into 时,请不要使用Oracle.ManagedDataAccess.Client.OracleCommand.ExecuteNonQuery。替代方案是:将merge into 的逻辑写在存储过程中,并在merge into 语句后添加 sql%rowcount 作为受merge into 影响的行数 返回给out 参数。
至于不稳定的原因 merge into 在 ExecuteNonQuery 的返回值表现不稳定的原因,希望能有高人指点。