首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用ODP.NET按名称绑定查询参数

使用ODP.NET按名称绑定查询参数
EN

Stack Overflow用户
提问于 2009-06-25 23:04:25
回答 3查看 16K关注 0票数 17

我目前使用的是Microsoft (System.Data.OracleClient)。我知道它肯定不是最好的甲骨文提供商,而且它是will soon be deprecated的,我应该改用甲骨文的ODP.NET。我仍然使用MS提供程序的原因是因为ODP.NET通过位置而不是名称来绑定参数。当您在查询中使用许多参数时,这可能真的是一个难题,因为您必须小心地以正确的顺序添加它们,这很容易导致错误。当您在同一查询中多次使用同一参数时,这也很烦人,例如:

代码语言:javascript
复制
SELECT A,B,C FROM FOO WHERE X = :PARAM_X OR :PARAM_X = 0

使用ODP.NET,我必须向OracleCommand添加两个参数,我认为这很愚蠢……

has的OracleCommand有一个用于更改默认行为的属性:BindByName。当设置为true时,参数通过名称进行绑定,这正是我想要的。不幸的是,这对我没有真正的帮助,因为:

  • 默认设置为false
  • 我几乎从不显式使用具体的ADO.NET类,我更喜欢使用ADO.NET 2.0抽象层(DbProviderFactoryDbConnectionDbCommand...)以减少到任何特定RDBMS的耦合。因此,我没有访问BindByName属性的权限,除非我显式强制转换为OracleCommand,失去所有好处或使用ASP.NET SqlDataSource创建abstraction.
  • When,否则我不会自己创建DbCommand,因此我没有机会将BindByName设置为true (我可以在Selecting事件中设置,但对于每个SqlDataSource...)

来说,这样做真的很痛苦

我该怎么处理这个问题呢?有没有BindByNameByDefault设置?(我没有找到这样的东西,但我可能错过了…)

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-06-26 09:19:55

我认为您可以创建自己的提供程序,使用您想要使用的默认值。您可以通过继承odp.net的所有类来轻松创建该提供程序,只需调整一些属性,如BindByName。

DbProviderfactory将创建您的类,而不是普通的odp.net类。

票数 7
EN

Stack Overflow用户

发布于 2009-07-28 20:09:25

使用间接和继承!如果通过抽象数据库类执行数据访问,则需要Database实现句柄参数绑定。

代码语言:javascript
复制
public abstract class Database
{
    private readonly DbProviderFactory factory;

    protected Database(DbProviderFactory factory)
    {
        this.factory = factory;
    }

    public virtual DbCommand CreateCommand(String commandText)
    {
        return CreateCommand(CommandType.Text, commandText);
    }

    public virtual DbCommand CreateCommand(CommandType commandType, String commandText)
    {
        DbCommand command = factory.CreateCommand();
        command.CommandType = commandType;
        command.Text = commandText;
        return command;
    }

    public virtual void BindParametersByName(DbCommand command)
    {

    }
}

并选择创建覆盖默认命令创建的Oracle特定实现,或提供按名称绑定参数的选项。

代码语言:javascript
复制
public class OracleDatabase : Database
{
    public OracleDatabase()
        : base(OracleClientFactory.Instance)
    {

    }

    public override DbCommand CreateCommand(CommandType commandType, String commandText)
    {
        DbCommand command = base.CreateCommand(commandType, commandText);
        BindParametersByName(command);
        return command;
    }

    public override void BindParametersByName(DbCommand command)
    {
        ((OracleCommand)command).BindByName = true;
    }
}

基于中的的代码。

票数 4
EN

Stack Overflow用户

发布于 2009-06-26 12:17:52

至于停止使用Microsoft ADO .NET provider for Oracle:

我将继续使用它而不是

  • .NET,你的问题只是它众多问题中的一个。随着它的发展,它在ADO4.0中仍然可用,尽管unsupported.
  • If .NET设法使这个提供程序不可用,但我可能会使用完全集成到ADO .NET框架中的商业替代方案,如DataDirect ADO.NET Data Provider for OracledotConnect for Oracle。顺便说一句,他们已经支持实体框架了(我相信甲骨文声明的ODP.NET不会)。

ODP .NET已经占用了我太多的时间。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1046632

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档