linq 如何在ASP.NET MVC中做多个下拉列表搜索?

zvokhttg  于 2022-12-20  发布在  .NET
关注(0)|答案(2)|浏览(173)

我有搜索日期时间从日期到日期。我需要添加下拉列表“Catruc”,但我不知道如何在Linq。
enter image description here
数据库选择查询“Catruc”
enter image description here
enter image description here
查看:
enter image description here
管理员:我怎样才能把“Catruc”加到“where”里面呢???

public DongphuocDbContext db = new DongphuocDbContext();

        // GET: Report
        public ActionResult Index(DateTime? start, DateTime? end)
        {
            var query = db.View_XeQuaTramReport;
            if (start == null || end == null)
                {
                return View();
            }
            DateTime strStart = start.Value.Date;
            DateTime strEnd = end.Value.Date;
            var result = db.View_XeQuaTramReport
                .Where(r => r.NgayCa >= strStart && r.NgayCa <= strEnd)
                .GroupBy(r => new { r.LoaiVe, r.LoaiXe, r.Phi })
                .Select(g => new XeQuaTramDTO
                {
                    LoaiVe = g.Key.LoaiVe,
                    LoaiXe = g.Key.LoaiXe,
                    Phi = g.Key.Phi,
                    TongPhi = g.Sum(r => r.Phi),
                    TongXe = g.Count()
                })
                .OrderBy(r => new { r.LoaiVe, r.LoaiXe, r.Phi, r.TongPhi, r.TongXe })
                .ToList();

            return View(result);
        }

    }
zsohkypk

zsohkypk1#

根据您的查询结果,这应该可以工作:

public ActionResult Index(DateTime? start, DateTime? end)
        {
            var query = db.View_XeQuaTramReport;
            if (start == null || end == null)
                {
                return View();
            }
            DateTime strStart = start.Value.Date;
            DateTime strEnd = end.Value.Date;
            var result = db.View_XeQuaTramReport
                .Where(r => r.NgayCa >= strStart && r.NgayCa <= strEnd && r.CaTruc == 1)
                .GroupBy(r => new { r.LoaiVe, r.LoaiXe, r.Phi })
                .Select(g => new XeQuaTramDTO
                {
                    LoaiVe = g.Key.LoaiVe,
                    LoaiXe = g.Key.LoaiXe,
                    Phi = g.Key.Phi,
                    TongPhi = g.Sum(r => r.Phi),
                    TongXe = g.Count()
                })
                .OrderBy(r => new { r.LoaiVe, r.LoaiXe, r.Phi, r.TongPhi, r.TongXe })
                .ToList();

            return View(result);
        }

如果您还想在select中包含该值,则需要将其添加到groupby:

public ActionResult Index(DateTime? start, DateTime? end)
            {
                var query = db.View_XeQuaTramReport;
                if (start == null || end == null)
                    {
                    return View();
                }
                DateTime strStart = start.Value.Date;
                DateTime strEnd = end.Value.Date;
                var result = db.View_XeQuaTramReport
                    .Where(r => r.NgayCa >= strStart && r.NgayCa <= strEnd && r.CaTruc == 1)
                    .GroupBy(r => new { r.CaTruc, r.LoaiVe, r.LoaiXe, r.Phi })
                    .Select(g => new XeQuaTramDTO
                    {
                        CaTruc = g.Key.Catruc,
                        LoaiVe = g.Key.LoaiVe,
                        LoaiXe = g.Key.LoaiXe,
                        Phi = g.Key.Phi,
                        TongPhi = g.Sum(r => r.Phi),
                        TongXe = g.Count()
                    })
                    .OrderBy(r => new { r.LoaiVe, r.LoaiXe, r.Phi, r.TongPhi, r.TongXe })
                    .ToList();
    
                return View(result);
            }
bnl4lu3b

bnl4lu3b2#

查看:

<center>
<p>
    @using (Html.BeginForm("Index", "Report", FormMethod.Get))
    {
    <div class="col-4 "><form method="post"> <div class="form-group">
                <label>Ca trực</label>
                <select class="form-control" id="nhanvien">
                </select></div> </form>
        <input type="date" name="start" />
        <input type="date" name="end" />
        <input type="submit" name="submit" value="Search" />
    </div>
       
    }
</p>
<table class="table">
    <tr>
        <th>LoaiVe </th>
        <th> Loaixe</th>
        <th>Phi </th>
        <th>Tong phi </th>
        <th>Tong xe </th>
    </tr>
    @if (Model != null)
    {
        if (Model.Count > 0)
        {
            foreach (var item in Model)
            {
                <tr>
                    <td> @Html.DisplayFor(modelItem => item.LoaiVe)</td>
                    <td> @Html.DisplayFor(modelItem => item.LoaiXe)</td>
                    <td> @Html.DisplayFor(modelItem => item.Phi)</td>
                    <td> @Html.DisplayFor(modelItem => item.TongPhi)</td>
                    <td> @Html.DisplayFor(modelItem => item.TongXe)</td>
                </tr>
            }
        }

    }
</table>

相关问题