0

我有这样的代码,我该如何设置“CommnadTimeout”?

var database = EnterpriseLibraryContainer.Current.GetInstance<Database>();
var sqlGetAllPersons = @"select * from Person.Person";
var personMapper = MapBuilder<Person>.MapAllProperties().Build();

// create an accessor (DataAccessor)
var personAccessor = database.CreateSqlStringAccessor<Person>(sqlGetAllPersons, personMapper);

// execute the accessor (IEnumerable<Person>)
var profiles = personAccessor.Execute();

EntLib 5.0 DAAB MapBuilder 的代码将 DBNull 映射到 null

谢谢

4

1 回答 1

1

虽然我不喜欢这个解决方案,但我能够通过这种方式修复它:

public class ParameterMapperWithCommandTimeout : IParameterMapper
{
    public int CommandTimeout { get; set; }

    public void AssignParameters(DbCommand command, object[] parameterValues)
    {
        command.CommandTimeout = this.CommandTimeout;
    }
}

应用于前面的例子:

var database = EnterpriseLibraryContainer.Current.GetInstance<Database>();
var sqlGetAllPersons = @"select * from Person.Person";
var personMapper = MapBuilder<Person>.MapAllProperties().Build();
var parameterMapper = new ParameterMapperWithCommandTimeout { CommandTimeout = MyTimeOut };

// create an accessor (DataAccessor)
var personAccessor = database.CreateSqlStringAccessor<Person>(sqlGetAllPersons, parameterMapper, personMapper);

// execute the accessor (IEnumerable<Person>)
var profiles = personAccessor.Execute();
于 2012-11-29T21:21:10.937 回答