EF数据Linq方式查询

using (var ctx = new AppDbContext())
            {
                //单表查询SQL查询方式
                //SELECT * FROM Customers AS c WHERE c.City = 'London' AND c.CustomerID = 'EASTC'
                dataGridView1.DataSource = (from c in ctx.Customers where c.City == "London" && c.CustomerID == "EASTC" select c).ToList();

                //模糊查询
                //SELECT * FROM Customers AS c WHERE c.City LIKE 'L%'
                dataGridView1.DataSource = (from c in ctx.Customers where c.City.StartsWith("L") select c).ToList();
                //SELECT * FROM Customers AS c WHERE c.City LIKE '%L'
                dataGridView1.DataSource = (from c in ctx.Customers where c.City.EndsWith("L") select c).ToList();
                //SELECT * FROM Customers AS c WHERE c.City LIKE '%L%'
                dataGridView1.DataSource = (from c in ctx.Customers where c.City.Contains("L") select c).ToList();
                //SELECT * FROM Customers AS c WHERE c.City='London' ORDER BY c.CustomerID

                //排序
                //SELECT * FROM Customers AS c WHERE c.City='London' ORDER BY c.CustomerID
                dataGridView1.DataSource = (from c in ctx.Customers where c.City == "London" orderby c.CustomerID select c).ToList();

                //只查询部分列,并排序
                //SELECT c.CustomerID, c.CompanyName, c.ContactName FROM Customers AS c
                //WHERE c.CompanyName = 'The Big Cheese'
                //ORDER BY c.CompanyName
                dataGridView1.DataSource = (from c in ctx.Customers where c.CompanyName == "The Big Cheese" orderby c.CompanyName select new { c.CustomerID, c.CompanyName, c.ContactName }).ToList();

                //分组
                //SELECT c.City,COUNT(c.CompanyName) FROM Customers AS c GROUP BY c.City
                dataGridView1.DataSource = (from c in ctx.Customers group c by c.City into r orderby r.Count() descending select new { City = r.Key, Count = r.Count() }).ToList();
            }
        }

 

posted @ 2021-08-08 08:32  清语堂  阅读(118)  评论(0编辑  收藏  举报