0

如何将此存储过程迁移到 LINQ

DECLARE @customerIDs TABLE (customerID INT)
DECLARE @c INT

if (@customerName != '')
BEGIN
    INSERT INTO @customerIDs
    select id from customer
    where name like '%' + @customerName + '%'

    SELECT @c = COUNT(*) FROM @customerIDs  
END
else
    SET @c = 0

-- Insert statements for procedure here
SELECT DISTINCT l.*, dbo.GetListOfBranches(l.id) as 'list_of_branches', dbo.GetTopLevelCustomer(cid.customerID) FROM [login] l
LEFT JOIN login_to_customer ltc ON ltc.login_id = l.id
LEFT JOIN @customerIDs cid ON cid.customerID = ltc.customer_id
WHERE 
(@c = 0 OR ltc.customer_id = cid.customerID) AND
(l.surname LIKE '%' + ISNULL(@surname, l.surname) + '%')  AND
(l.forename LIKE '%' + ISNULL(@forename, l.forename) + '%')  AND
 (user_type = ISNULL(@userType, user_type))  AND
 (l.active = ISNULL(@active, l.active)) 
 ORDER BY surname ASC

到目前为止,我已经得到了这个:

List<Int32> customerIds = new List<int>();           
        if (!String.IsNullOrEmpty(customerName))
        {
            CustomerDataContext custDataContext = new CustomerDataContext();

            customerIds = (from a in custDataContext.Customers
                           where a.name.Contains(customerName)
                           select a.id).ToList<Int32>();
        }

        LoginDataContext dataContext = new LoginDataContext();

        var query = (from t in dataContext.logins
                     join t2 in dataContext.login_to_customers on t.id equals t2.login_id into a
                     from subquery in a.DefaultIfEmpty()
                     select new { t, listOfBranches = dataContext.GetListOfBranches(t.id), topLevelCustomer = dataContext.GetTopLevelCustomer(t.id) });

我需要然后做一个

if (customerIds.Count() > 0)
{
    query = query.Where(a => customerIds.Contains(a.t.customer_id))
}

但是由于我需要执行不同的操作,因此我不能在查询中包含 customer_id 列。有没有办法包括

LEFT JOIN @customerIDs cid ON cid.customerID = ltc.customer_id
    WHERE 
    (@c = 0 OR ltc.customer_id = cid.customerID)

在 LINQ 内?

谢谢,理查德

4

0 回答 0