-1

我一直在寻找这个问题的答案,但仍然有问题,想知道我做错了什么......

我有我的 MVC 项目,并且正在使用 LINQ 从我的数据库中的两个表中获取数据。我需要离开加入第二张桌子但是我收到一个错误

你调用的对象是空的

问题出在我的模型中,尤其是正在连接的表中。这是我的代码:

public void DATA(string searchString)
        {
            newList = new List<ResultsList>();

            var res = from f in searchDB.CUSTOMERS

                      join cd in searchDB.CUSTOMER_DETAILS
                        on f.cust_id equals cd.cust_id into grouped
                        from gr in grouped.DefaultIfEmpty()

                      where f.ProductName.Equals(searchString)
                      select new { f, gr };


        foreach (var item in surname)
        {
            ResultsList rl = new ResultsList();

            rl.Forename = item.f.Forename;
            rl.Postcode = item.gr.postcode;
            rl.ProductName = item.f.ProductName;

            newList.Add(rl);
        }
    }
4

2 回答 2

4

您可以通过编写以下代码来简化代码并摆脱 for 循环:

var rl = (from f in searchDB.CUSTOMERS
          join cd in searchDB.CUSTOMER_DETAILS
            on f.cust_id equals cd.cust_id into grouped
          from gr in grouped.DefaultIfEmpty()
          where f.ProductName == searchString
          select new ResultsList
          {
              Forename = f.Forename,
              Postcode = gr == null ? null : gr.postcode,
              ProductName = f.ProductName
          }).ToList();

它也可能适用Postcode = gr.postcode。取决于 Linq 数据库提供程序的智能程度。

于 2013-10-07T18:48:24.220 回答
-5

抱歉,它应该是“res”,但这不是问题。无论如何,我已经解决了这个问题。如果有人有兴趣,我就是这样做的。

在 foreach 部分,我添加了一个 if 语句来查看连接表中的列是否为空,然后应用我需要的所有内容减去连接列,否则我使用了两个表中所需的所有内容。

foreach (var item in res)
        {
            ResultsList rl = new ResultsList();

            if (item.gr != null)
            {
                rl.Forename = item.f.Forename;
                rl.Postcode = item.gr.postcode;
                rl.ProductName = item.f.ProductName;
            }
            else
            {
                rl.Forename = item.f.Forename;
                rl.ProductName = item.f.ProductName;

            }
于 2013-10-07T16:13:48.420 回答