Binding query parameters by name with ODP.NET

前端 未结 3 436
忘了有多久
忘了有多久 2020-12-10 02:18

I\'m currently using the Microsoft ADO.NET provider for Oracle (System.Data.OracleClient). I\'m aware that it is certainly not the best Oracle provider availabl

相关标签:
3条回答
  • 2020-12-10 02:57

    Use indirection and inheritance! If you're performing data access through an abstract Database class, require the Database implementation handle parameter binding.

    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)
        {
    
        }
    }
    

    And choose to create an Oracle specific implementation that overrides default command creation or provides the option to bind parameters by name.

    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;
        }
    }
    

    Code based on the Data Access Application Block in the Enterprise Library.

    0 讨论(0)
  • 2020-12-10 03:07

    I think you can create your own provider that uses the defaults you want to use. You could create that provider easily by inheriting all the classes from odp.net, just adjust some properties like BindByName.

    The DbProviderfactory will create your classes instead of the normal odp.net classes.

    0 讨论(0)
  • 2020-12-10 03:10

    As for the discontinuation of the Microsoft ADO .NET provider for Oracle :

    • I will go on using it instead of ODP .NET, your problem being only one of the numerous issues with it. And as it goes, it will still be available in .NET 4.0, though unsupported.
    • If Oracle manages to render this provider unusable, I will probably go with a commercial alternative such as DataDirect ADO.NET Data Provider for Oracle or dotConnect for Oracle, that fully integrate into the ADO .NET framework. And they already support the Entity Framework, by the way (I believe Oracle stated ODP .NET would not).

    ODP .NET took too much of my time already.

    0 讨论(0)
提交回复
热议问题