一、准备工作
在SqlServer上创建数据库:Element
模拟两个表并插入数据:SysUser(用户表)、SysRole(角色表)
CREATE TABLE [dbo].[SysUser](
[ID] [int] IDENTITY(1,1) NOT NULL,
[Name] [nchar](10) NOT NULL,
[RoleNum] [nchar](10) NOT NULL
) ON [PRIMARY]
CREATE TABLE [dbo].[SysRole](
[ID] [int] IDENTITY(1,1) NOT NULL,
[RoleName] [nchar](10) NOT NULL,
[RoleNum] [nchar](10) NOT NULL
) ON [PRIMARY]
插入数据:
data:image/s3,"s3://crabby-images/5a593/5a5933418c363740239c564fd38e34a21cacbd6c" alt=""
data:image/s3,"s3://crabby-images/52530/52530386cd0f6d0372dce4b94ab6abddb427a6b8" alt=""
data:image/s3,"s3://crabby-images/9dc3f/9dc3fc7291d44e58da280b9c8f42d9fb7c1afde8" alt=""
data:image/s3,"s3://crabby-images/e9327/e932755ee3d1d280f058fa436e3d2c29ecd8bbad" alt=""
data:image/s3,"s3://crabby-images/65dca/65dca235c0da0efaf08b3e2cf5d80b1955eb9959" alt=""
二、使用EF的Code First从原有数据库中生成Models
data:image/s3,"s3://crabby-images/9957a/9957a3ca2d3c9d50b7699ac66dddf3b245342740" alt=""
data:image/s3,"s3://crabby-images/2e199/2e199246ce34639aff8c085ec8f709a31a65d51b" alt=""
data:image/s3,"s3://crabby-images/6f50d/6f50d2e70d9134b6f8446e4de5e3d18eec1df2bb" alt=""
data:image/s3,"s3://crabby-images/cc8bd/cc8bd2c5a623f0fb23cac25b7d46851698f2b943" alt=""
data:image/s3,"s3://crabby-images/ac02d/ac02dcc53b78dff53fd53b16999014f8b00cfade" alt=""
data:image/s3,"s3://crabby-images/131bb/131bbbd8a67a3d4bdae3ee6704e9b40075ed1aa8" alt=""
data:image/s3,"s3://crabby-images/0f751/0f751abb0a821233103a9328e615deb60e0347a2" alt=""
data:image/s3,"s3://crabby-images/644d7/644d7ab524e8cda9fd5765c08c6c978753b8244c" alt=""
data:image/s3,"s3://crabby-images/dc385/dc385bb1ac48d790f57d9376a665d9d097d5ae6c" alt=""
data:image/s3,"s3://crabby-images/8dfe9/8dfe91c234869a0bfe33da14eb14de63f4a42668" alt=""
三、根据Model生成Controller及View
在Controllers文件夹上右键--添加--控制器
data:image/s3,"s3://crabby-images/dae01/dae014331398efca59c46a0d373806c2a0bd272e" alt=""
data:image/s3,"s3://crabby-images/9a43b/9a43bca45841b9bd402f82b3f72ee519f406a288" alt=""
data:image/s3,"s3://crabby-images/517aa/517aa14f046ead7ddeedc3e36c2a1f76c12be46d" alt=""
四、利用ViewModel显示多表联合查询
data:image/s3,"s3://crabby-images/a58c2/a58c21cce47068dcc216741464bd83b2c8a09308" alt=""
namespace MVCDemo.ViewModels
{
public class UserRole
{
public string userName { get; set; }
public string userRole { get; set; }
}
}
右键Controllers文件夹添加控制类,此类继承于Controller类
using System;
using System.Collections.Generic;
using System.Linq; using System.Web;
using System.Web.Mvc; using System.Data.Entity;
using MVCDemo.ViewModels;
using MVCDemo.Models;
namespace MVCDemo.Controllers
{
public class UserRoleController : Controller
{
ElementModel db = new ElementModel();
public ActionResult Index()
{
var userRoleList = from uu in db.SysUsers
join ud in db.SysRoles on uu.RoleNum equals ud.RoleNum
where uu.ID == 1
select new UserRole {userName = uu.Name,userRole = ud.RoleName}
return View(userRoleList);
}
}
}
@model IEnumerable<MVCDemo.ViewModels.UserRole>
@{
Layout = "~/Views/Shared/_Layout.cshtml";
}
<table class="table">
<tr>
<th>
@Html.DisplayNameFor(model=>model.userName)
</th>
<th>
@Html.DisplayNameFor(model => model.userRole)
</th>
<th></th>
</tr>
@foreach (var item in Model)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.userName)
</td>
<td>
@Html.DisplayFor(modelItem => item.userRole)
</td>
</tr>
}
</table>