我目前使用的是Microsoft (System.Data.OracleClient
)。我知道它肯定不是最好的甲骨文提供商,而且它是will soon be deprecated的,我应该改用甲骨文的ODP.NET。我仍然使用MS提供程序的原因是因为ODP.NET通过位置而不是名称来绑定参数。当您在查询中使用许多参数时,这可能真的是一个难题,因为您必须小心地以正确的顺序添加它们,这很容易导致错误。当您在同一查询中多次使用同一参数时,这也很烦人,例如:
SELECT A,B,C FROM FOO WHERE X = :PARAM_X OR :PARAM_X = 0
使用ODP.NET,我必须向OracleCommand
添加两个参数,我认为这很愚蠢……
has的OracleCommand
有一个用于更改默认行为的属性:BindByName
。当设置为true时,参数通过名称进行绑定,这正是我想要的。不幸的是,这对我没有真正的帮助,因为:
DbProviderFactory
,DbConnection
,DbCommand
...)以减少到任何特定RDBMS的耦合。因此,我没有访问BindByName
属性的权限,除非我显式强制转换为OracleCommand
,失去所有好处或使用ASP.NET SqlDataSource创建abstraction.BindByName
设置为true (我可以在Selecting事件中设置,但对于每个SqlDataSource...)来说,这样做真的很痛苦
我该怎么处理这个问题呢?有没有BindByNameByDefault
设置?(我没有找到这样的东西,但我可能错过了…)
https://stackoverflow.com/questions/1046632
复制相似问题