5

我试图Enumerable.ContainsSqlExpressionVisitor.Where子句中使用查询我的数据库。编译 lambda 时,我得到一个空引用异常。

当访问者到达foreach (Object e in inArgs)(当前为第 1067 行) insideSqlExpressionVisitor.VisitArrayMethodCall时,它​​会因为inArgs为空而窒息。以下是导致错误的示例。我不太了解 lambdas/表达式,无法知道为什么会发生这种情况。

所以我的问题是,我没有Where正确使用该子句还是这是一个错误?

class Program
{
    static void Main(string[] args)
    {
        var connectionFactory = new OrmLiteConnectionFactory(@"Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|Database1.mdf;Integrated Security=True;User Instance=True", SqlServerDialect.Provider);
        SetupDb(connectionFactory);           

        using (var db = connectionFactory.OpenDbConnection())
        {
            var numbersToSelect = new int[2] { 1, 2 };
            db.Select<SomeObject>(e => e.Where(o => numbersToSelect.Contains(o.Number)));
        }
    }

    static void SetupDb(IDbConnectionFactory connectionFactory)
    {
        using (var db = connectionFactory.OpenDbConnection())
        {
            db.DropTable<SomeObject>();
            db.CreateTable<SomeObject>();
            db.Insert(new SomeObject { Number = 1 });
            db.Insert(new SomeObject { Number = 2 });
            db.Insert(new SomeObject { Number = 3 });
            db.Insert(new SomeObject { Number = 4 });
            db.Insert(new SomeObject { Number = 5 });
        }
    }
}

class SomeObject
{
    public int Number { get; set; }
}

经过一番挖掘,事实证明调用已编译的方法会返回一个int[]导致强制转换object[]为空的方法。铸造以IEnumerable解决我的具体问题。

改变了

var getter = lambda.Compile();
var inArgs = getter() as object[];

var getter = lambda.Compile();
var inArgs = getter() as IEnumerable;

不确定这有什么影响(如果有的话)。仍在寻找一些指导。

4

2 回答 2

8

不要使用包含,而是使用 Sql.In

db.Select<SomeObject>(e => e.Where(o => Sql.In(o.Number,numbersToSelect)));

于 2013-07-18T00:42:02.083 回答
2

原来这是一个错误。从提交 9f0b0e8开始,它已针对 sqlite 访问者和 sql 访问者进行了修复,谢谢@mythz。

于 2013-07-19T02:54:26.817 回答