MVC联表查询

本文介绍了在MVC中如何进行联表查询,详细解释了控制器中的数据库操作,涉及到SetMealDetailVo实体类及其字段。查询过程中,通过SetMealDetail、WGItem、WGSmall和WGBig之间的外键关系实现多表连接。之后,通过where条件筛选获取所有字段,并实现了数据的分页展示。最后展示了联表查询和分页显示的实际效果。
摘要由CSDN通过智能技术生成

开发工具与关键技术: Visual Studio 2015    mvc 

作者:彭水清



撰写时间:2019/6/2



学习MVC,我们都离不开增、删、查、改,那么接下来我们就来说一说怎样现实MVC的联表查询吧。

那么在写联表查询时,我们需要用到layui.js这个插件。

我们需要给它设计数据表头,type类型为'radio'和'numbers',field设定字段名。字段名的设定非常重要,且是表格数据列的唯一标识。Title设定标题名称。

tabSetMealDetail = layuiTable.render({

 
  elem: "#tabSetMealDetail",

     url: "",

 
  cols: [[

  { type: 'radio', fixed: 'left',
title: '选择', align: "center"
},//单选框列,fixed:'left' 将列固定在左边

{ type: 'numbers', title: '序号', align: "center" },//序号列,title设定标题名称

{
field: 'SetMealSetID', title: 'SetMealSetID', hide: true,
align: "center" },//hide:true 隐藏列

{
field: 'SetMealDetailID', title: 'SetMealDetailID', hide: true,
align: "center" },//hide:true 隐藏列

 
{ field: 'WGNumber', title: '编号', align: "center" },
如果您的MVC项目涉及到了多个表的联合查询,那么您需要将查询结果传递到视图层进行展示。一般情况下,您可以在控制器层调用一个服务层方法来完成查询,并将结果存储在一个数据模型。 接着,您可以将这个数据模型传递给视图层进行展示。在视图层,您可以使用 Razor 语法或者其他模板引擎来访问这个数据模型,并将数据渲染到 HTML 页面。 更具体地说,您可以在控制器层创建一个服务层方法,该方法可以返回一个包含所有数据数据模型。例如: ``` public class MyController : Controller { private readonly MyService _service; public MyController(MyService service) { _service = service; } public async Task<IActionResult> Index() { var dataModel = await _service.GetCombinedData(); return View(dataModel); } } ``` 在上面的代码,我们在控制器层调用了一个名为 `GetCombinedData()` 的服务层方法,并将查询结果存储在一个数据模型。接着,我们将这个数据模型传递给视图层进行展示。 在视图层,您可以使用 Razor 语法来访问这个数据模型,并将数据渲染到 HTML 页面。例如: ``` @model MyDataModel <h1>@Model.Title</h1> <ul> @foreach (var item in Model.Items) { <li>@item.Name</li> } </ul> ``` 在上面的代码,我们通过 `@model` 指令指定了视图所使用的数据模型类型。接着,我们使用 Razor 语法来访问数据模型数据,并将数据渲染到 HTML 页面。 当您在浏览器访问这个页面时,ASP.NET MVC 框架会自动将数据模型传递给视图,并将渲染后的 HTML 页面返回给浏览器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值