1.数据库原型(Students表中的ID和Scores表中的StudentID是对应的)

2.实现效果:查询出每个学生各个科目的成绩(用的是MVC学习笔记(三)—用EF向数据库中添加数据的架构)

C#代码

        public ActionResult Index()
{
try
{
EFContextDB db = new EFContextDB();
List<StudentScoreView> scoreList = new List<StudentScoreView>();
scoreList = (from s in db.Students
join
c in db.Scores on s.ID equals c.StudentID
select new StudentScoreView
{
ID = s.ID,
Name = s.Name,
Subject = c.Subject,
Score = c.StudentScore,
School = s.School
}).ToList();
return Json(scoreList, JsonRequestBehavior.AllowGet);
}
catch(Exception ex)
{
return Json("err", JsonRequestBehavior.AllowGet);
}
}

加了一个显示类studentScoreView

    public class StudentScoreView
{
/// <summary>
/// 主键
/// </summary>
public Guid ID { get; set; }
/// <summary>
/// 姓名
/// </summary>
public string Name { get; set; }
/// <summary>
/// 学校
/// </summary>
public string School { get; set; } /// <summary>
/// 分数
/// </summary>
public int Score { get; set; } /// <summary>
/// 科目
/// </summary>
public string Subject { get; set; }
}

3.最后返回json结果

[{
"ID": "5eaaff20-f806-4116-a387-39b44c4c76e0",
"Name": "李四",
"School": "厦门大学",
"Score": ,
"Subject": "语文"
}, {
"ID": "5eaaff20-f806-4116-a387-39b44c4c76e0",
"Name": "李四",
"School": "厦门大学",
"Score": ,
"Subject": "数学"
}, {
"ID": "5eaaff20-f806-4116-a387-39b44c4c76e0",
"Name": "李四",
"School": "厦门大学",
"Score": ,
"Subject": "英语"
}, {
"ID": "662bf2f7-3680-490c-8ff8-9208e4e5f362",
"Name": "张三",
"School": "北京大学",
"Score": ,
"Subject": "语文"
}, {
"ID": "662bf2f7-3680-490c-8ff8-9208e4e5f362",
"Name": "张三",
"School": "北京大学",
"Score": ,
"Subject": "数学"
}, {
"ID": "662bf2f7-3680-490c-8ff8-9208e4e5f362",
"Name": "张三",
"School": "北京大学",
"Score": ,
"Subject": "英语"
}, {
"ID": "5eaaff20-f806-4116-a387-39b44c4c76e0",
"Name": "小明",
"School": "中山大学",
"Score": ,
"Subject": "语文"
}, {
"ID": "4321592e-863f-411a-b044-9478952c29d1",
"Name": "小明",
"School": "中山大学",
"Score": ,
"Subject": "数学"
}, {
"ID": "4321592e-863f-411a-b044-9478952c29d1",
"Name": "小明",
"School": "中山大学",
"Score": ,
"Subject": "英语"
}]

linq中多条件的写法 用&&来连接

4.在实际过程中可能会遇到格式化字符串等等,按照下面方式(加上AsEnumerable())就可以了。

         public ActionResult Index()
{
try
{
EFContextDB db = new EFContextDB();
List<StudentScoreView> scoreList = new List<StudentScoreView>();
scoreList = (from s in db.Students.AsEnumerable()
join
c in db.Scores.AsEnumerable() on s.ID equals c.StudentID
select new StudentScoreView
{
ID = s.ID,
Name = s.Name,
Subject = c.Subject,
Score = c.StudentScore,
School = s.School,
ApplyTime = i.CreateTime.ToString("yyyy-MM-dd HH:mm:ss")
}).ToList();
return Json(scoreList, JsonRequestBehavior.AllowGet);
}
catch(Exception ex)
{
return Json("err", JsonRequestBehavior.AllowGet);
}
}

小插曲:中间在编译的过程中,遇到了“未能找到查询的实现”,解决方法是引用命名空间:using System.Linq

写在后面的话:不积跬步无以至千里,我喜欢用文字记录下自己学习的过程,虽然每一篇都是小知识点,每一篇都很简单,但我相信量变会引起质变,加油!

MVC学习笔记(四)---使用linq多表联查(SQL)的更多相关文章

  1. C# LINQ学习笔记四:LINQ to OBJECT之操作文件目录

    本笔记摘抄自:https://www.cnblogs.com/liqingwen/p/5816051.html,记录一下学习过程以备后续查用. 许多文件系统操作实质上是查询,因此非常适合使用LINQ方 ...

  2. Linq学习笔记四之linq to sql 的基本操作

    首先需要在项目中新增一个 linq  to sql 的服务 新增项,数据,LINQ TO sql 类的这个方法 第二步需要一个model类,用作映射 [Table] public class S_ZD ...

  3. C#学习笔记四(LINQ,错误和异常,异步编程,反射元数据和动态编程)

    LINQ 1.使用类似的数据库语言来操作集合? 错误和异常 异步编程 1.异步和线程的区别: 多线程和异步操作两者都可以达到避免调用线程阻塞的目的.但是,多线程和异步操作还是有一些区别的.而这些区别造 ...

  4. .NET MVC 学习笔记(四)— 基于Bootstarp自定义弹出框

    .NET MVC 学习笔记(四)—— 基于Bootstarp自定义弹出框 转载自:https://www.cnblogs.com/nele/p/5327380.html (function ($) { ...

  5. ASP.NET MVC 学习笔记-2.Razor语法 ASP.NET MVC 学习笔记-1.ASP.NET MVC 基础 反射的具体应用 策略模式的具体应用 责任链模式的具体应用 ServiceStack.Redis订阅发布服务的调用 C#读取XML文件的基类实现

    ASP.NET MVC 学习笔记-2.Razor语法   1.         表达式 表达式必须跟在“@”符号之后, 2.         代码块 代码块必须位于“@{}”中,并且每行代码必须以“: ...

  6. C#可扩展编程之MEF学习笔记(四):见证奇迹的时刻

    前面三篇讲了MEF的基础和基本到导入导出方法,下面就是见证MEF真正魅力所在的时刻.如果没有看过前面的文章,请到我的博客首页查看. 前面我们都是在一个项目中写了一个类来测试的,但实际开发中,我们往往要 ...

  7. Spring MVC 学习笔记12 —— SpringMVC+Hibernate开发(1)依赖包搭建

    Spring MVC 学习笔记12 -- SpringMVC+Hibernate开发(1)依赖包搭建 用Hibernate帮助建立SpringMVC与数据库之间的联系,通过配置DAO层,Service ...

  8. Spring MVC 学习笔记8 —— 实现简单的用户管理(4)用户登录

    Spring MVC 学习笔记8 -- 实现简单的用户管理(4)用户登录 增删改查,login 1. login.jsp,写在外面,及跟WEB-INF同一级目录,如:ls Webcontent; &g ...

  9. .NET MVC 学习笔记(五)— Data Validation

    .NET MVC 学习笔记(五)—— Data Validation 在实际应用中,我们需要对数据进行增查改删业务,在添加和修改过程中,无论你编写什么样的网页程序,都需要对用户的数据进行验证,以确数据 ...

随机推荐

  1. UDF——提取指定线上随时间变化的物理量

    Fluent版本:Fluent 19.0 Visual Studio版本:Visual Studio 2013 有时候我们想要实现一些功能,比如:我们在使用Fluent进行瞬态计算的时候,想要获取某条 ...

  2. Nginx服务器作反向代理实现内部局域网的url转发配置

    情景 由于公司内网有多台服务器的http服务要映射到公司外网静态IP,如果用路由的端口映射来做,就只能一台内网服务器的80端口映射到外网80端口,其他服务器的80端口只能映射到外网的非80端口.非80 ...

  3. Pandas 与 Numpy 常用方法总结

    Lambda 函数实现 简单的说,lambda 就是一个函数,但是这个函数没有名字,所以我们介绍一下这个函数的调用形式,参数与返回值的实现. lambda 的格式如下: lambda [arg1 [, ...

  4. vs code搭建python和tensorflow环境

    anaconda 安装tensorflow-gpu环境见https://www.cnblogs.com/wintersoft/p/11620267.html vscode中设置python虚拟环境Ct ...

  5. python 使用夜神模拟器

    安装版本为6.2.8.0 1.模拟器安装证书 打开模拟器,点击浏览器 在浏览器里输入:mitm.it 出现如下: 选择安卓进行安装 比如:sks123 2.设置代理 输入密码:sks123 上面刚才设 ...

  6. sql server中raiserror的用法(动态参数传值)

    1.raiserrror定义: 返回用户定义的错误信息并设系统标志,记录发生错误.通过使用 RAISERROR 语句,客户端可以从 sysmessages 表中检索条目, 或者使用用户指定的严重度和状 ...

  7. HandlerMethodReturnValueHandler SpringMVC 参数解析 继承关系以及各解析器解析类型

    I HandlerMethodReturnValueHandler (org.springframework.web.method.support) AbstractMessageConverterM ...

  8. 爬虫中采集动态HTML介绍

    JavaScript JavaScript 是网络上最常用也是支持者最多的客户端脚本语言.它可以收集 用户的跟踪数据,不需要重载页面直接提交表单,在页面嵌入多媒体文件,甚至运行网页游戏. 我们可以在网 ...

  9. 【转】模糊测试(fuzzing)是什么

    一.说明 大学时两个涉及“模糊”的概念自己感觉很模糊.一个是学数据库出现的“模糊查询”,后来逐渐明白是指sql的like语句:另一个是学专业课时出现的“模糊测试”. 概念是懂的,不外乎是“模糊测试是一 ...

  10. Starting Jenkins bash: /usr/bin/java: 没有那个文件或目录

    [root@localhost /]# systemctl status jenkins.service ● jenkins.service - LSB: Jenkins Automation Ser ...