第十四节:Lambda、linq、SQL的相爱相杀(3)
一. SQL 开篇
1. where用法
#region 封装EF调用SQL语句查询
public static List<T> ExecuteQuery<T>(string sql, params SqlParameter[] pars)
{
return db.Database.SqlQuery<T>(sql, pars).ToList();
}
#endregion
#region 01-where用法
{
//1. where用法
//1.1 查询账号为admin的用户信息
Console.WriteLine("---------------------------- 1. where用法 ----------------------------------------");
Console.WriteLine("---------------------------- 1.1 查询账号为admin的用户信息 ----------------------------------------");
string sql1 = @"select * from Sys_UserInfor where userAccount = 'admin'";
List<Sys_UserInfor> sUserList1 = ExecuteQuery<Sys_UserInfor>(sql1);
foreach (var item in sUserList1)
{
Console.WriteLine("用户名:{0},用户账号:{1},用户年龄:{2},用户性别:{3}", item.userName, item.userAccount, item.userAge, item.userSex);
}
//1.2 查询账号为中包含admin且性别为男的用户信息
Console.WriteLine("---------------------------- 1.2 查询账号为中包含admin且性别为男的用户信息 ----------------------------------------");
string sql2 = @"select * from Sys_UserInfor where userAccount like '%admin%' and userSex='男'";
List<Sys_UserInfor> sUserList2 = ExecuteQuery<Sys_UserInfor>(sql2);
foreach (var item in sUserList2)
{
Console.WriteLine("用户名:{0},用户账号:{1},用户年龄:{2},用户性别:{3}", item.userName, item.userAccount, item.userAge, item.userSex);
}
}
#endregion

2. select用法
#region 02-select用法
{
//2. select用法 (SQL语句中,查询部分字段,必须要有个实体接收,不能用var类型接收)
//2.1 查询账号中包含 admin 的用户的 姓名、年龄和性别 三条信息
Console.WriteLine("---------------------------- 2. select用法 ----------------------------------------");
Console.WriteLine("-------------2.1 查询账号中包含 admin 的用户的 姓名、年龄和性别 三条信息 )-------------------------");
string sql1 = @"select userName,userAge,userSex from Sys_UserInfor where userAccount like '%admin%'";
List<model1> sUserList1 = ExecuteQuery<model1>(sql1);
sUserList1.ForEach(u =>
{
Console.WriteLine("用户名:{0},用户年龄:{1},用户性别:{2}", u.userName, u.userAge, u.userSex);
}); }
#endregion

3. order by用法
#region 03-order by用法
{
//区分:在Lambda中有 orderby(OrderByDescending、ThenBy、ThenByDescending),但在SQL中 只有order by asc(默认是升序) 和order by desc
//需要按照多个条件进行升序或降序,格式为: order by x1, x2 descending,x3(表示先按照x1升序排,x1相同的话,再按照x2降序排,x2相同的话,在按照x3升序排列)
//3. Order By用法 (单条件升降序、多条件综合排序)
//3.1 查询delflag 为1 的所有用户信息,按照时间升序排列
Console.WriteLine("------3. orderby用法 (单条件升降序、多条件综合排序)-------------");
Console.WriteLine("--------------------- 3.1 查询delflag 为1 的所有用户信息,按照时间升序排列 ------------------------------"); string sql1 = @"select * from Sys_UserInfor where delFlag =1 order by addTime";
List<Sys_UserInfor> sUserList1 = ExecuteQuery<Sys_UserInfor>(sql1);
foreach (var item in sUserList1)
{
Console.WriteLine("用户名:{0},用户账号:{1},用户年龄:{2},用户性别:{3},创建时间:{4}", item.userName, item.userAccount, item.userAge, item.userSex, item.addTime);
}
//3.2 查询delflag 为1 的所有用户信息,先按照时间升序排列,再按照年龄降序
Console.WriteLine("---------------3.2 查询delflag 为1 的所有用户信息,先按照时间升序排列,再按照年龄降序----------------------");
string sql2 = @"select * from Sys_UserInfor where delFlag =1 order by addTime,userAge desc";
List<Sys_UserInfor> sUserList2 = ExecuteQuery<Sys_UserInfor>(sql2);
foreach (var item in sUserList2)
{
Console.WriteLine("用户名:{0},用户账号:{1},用户年龄:{2},用户性别:{3},创建时间:{4}", item.userName, item.userAccount, item.userAge, item.userSex, item.addTime);
}
}
#endregion

4. 多表关联查询
用到的用户表和用户登录记录表中的数据如下:


SQL中的关联包括:内连接、外连接、全连接。
1.内连接:也叫等值连接,查询出来的结果是多表交叉共有的,关键字inner join进行连接,其中inner可以省略。
PS:SQL中一般没有给内连接分类的,但在linq中通常分为显示内连接和隐式内连接。
注意:单纯的select * from a,b是笛卡尔乘积。比如a表有5条数据,b表有3条数据,那么最后的结果有5*3=15条数据。但是如果对两个表进行关联:select * from a,b where a.id = b.id 意思就变了,此时就等价于:select * from a inner join b on a.id = b.id。即就是内连接,但是这种写法并不符合规范,可能只对某些数据库管用,如sqlserver。推荐最好不要这样写。最好写成inner join的写法。

2.外连接:左外连接和右外连接.分别用left join 或right join 关键字来连接。
(1).左外连接:查询出JOIN左边表的全部数据,JOIN右边的表不匹配的数据用NULL来填充。
(2).右外连接:查询出JOIN右边表的全部数据,JOIN左边的表不匹配的数据用NULL来填充。


3.全连接:返回左表和右表中所有没有匹配的行,用关键字 full join来表示,适用于SQLServer,MySQL中没有这种用法

//4.查询账号中含有admin的所有用户的用户昵称、账号、和登录信息
//4.1 内连接的写法1
Console.WriteLine("---------------04-多表关联查询--------------------");
Console.WriteLine("---------------4.1 内连接的写法1--------------------");
string sql1 = @"select a.userName,a.userAccount,b.loginCity,b.loginIp,b.loginTime
from Sys_UserInfor a,LoginRecords b
where a.id =b.userId";
List<model2> uList1 = ExecuteQuery<model2>(sql1);
foreach (var item in uList1)
{
Console.WriteLine("姓名:{0},账号:{1},登录城市:{2},登录IP:{3},登录时间:{4}", item.userName, item.userAccount, item.loginCity, item.loginIp, item.loginTime);
}
//4.2 内连接的写法2
Console.WriteLine("---------------4.2 内连接的写法2 --------------------");
string sql2 = @"select a.userName,a.userAccount,b.loginCity,b.loginIp,b.loginTime
from Sys_UserInfor a inner join LoginRecords b on a.id =b.userId"; List<model2> uList2 = ExecuteQuery<model2>(sql2);
foreach (var item in uList2)
{
Console.WriteLine("姓名:{0},账号:{1},登录城市:{2},登录IP:{3},登录时间:{4}", item.userName, item.userAccount, item.loginCity, item.loginIp, item.loginTime);
} //4.3 查询所有用户的登录信息(左外连接的方式)
Console.WriteLine("-----------------------4.3 查询所有用户的登录信息(左外连接的方式)----------------------------");
string sql3 = @"select a.userName,a.userAccount,b.loginCity,b.loginIp,b.loginTime
from Sys_UserInfor a left join LoginRecords b on a.id =b.userId
";
List<model2> uList3 = ExecuteQuery<model2>(sql3);
foreach (var item in uList3)
{
Console.WriteLine("姓名:{0},账号:{1},登录城市:{2},登录IP:{3},登录时间:{4}", item.userName, item.userAccount, item.loginCity, item.loginIp, item.loginTime);
} //4.4 查询所有用户的登录信息(右外连接的方式)
Console.WriteLine("-----------------------4.4 查询所有用户的登录信息(右外连接的方式)----------------------------");
string sql4 = @"select a.userName,a.userAccount,b.loginCity,b.loginIp,b.loginTime
from Sys_UserInfor a right join LoginRecords b on a.id =b.userId
";
List<model2> uList4 = ExecuteQuery<model2>(sql4);
foreach (var item in uList4)
{
Console.WriteLine("姓名:{0},账号:{1},登录城市:{2},登录IP:{3},登录时间:{4}", item.userName, item.userAccount, item.loginCity, item.loginIp, item.loginTime);
}
//4.5 查询所有用户的登录信息(全连接)
Console.WriteLine("-----------------------4.5 查询所有用户的登录信息(全连接)----------------------------");
string sql5 = @"select a.userName,a.userAccount,b.loginCity,b.loginIp,b.loginTime
from Sys_UserInfor a full join LoginRecords b on a.id =b.userId
";
List<model2> uList5 = ExecuteQuery<model2>(sql5);
foreach (var item in uList5)
{
Console.WriteLine("姓名:{0},账号:{1},登录城市:{2},登录IP:{3},登录时间:{4}", item.userName, item.userAccount, item.loginCity, item.loginIp, item.loginTime);
}
运行结果:

5. group By用法
group By分组(SQL中的group by分组和linq、lambda完全不同。特别注意:select指定的字段要么就要包含在Group By语句的后面,作为分组的依据;要么就要被包含在聚合函数中) 常见的聚合函数有:sum avg min max
#region 05-group By分组
{
//5. Group By分组(SQL中的group by分组和linq、lambda完全不同,
/*特别注意:select指定的字段要么就要包含在Group By语句的后面,作为分组的依据;要么就要被包含在聚合函数中)
常见的聚合函数有:sum avg min max
*/ //5.1 根据用户的性别进行分类,并且统计不同性别的年龄总和
Console.WriteLine("-------------------- 5. GroupBy分组------------------------");
Console.WriteLine("-------------------- 5.1 根据用户的性别进行分类,并且统计不同性别的年龄总和------------------------");
string sql1 = @"select userSex,SUM(userAge) as TotalAges
from Sys_UserInfor
group by userSex";
List<model3> sUserListGroup1 = ExecuteQuery<model3>(sql1);
foreach (var item in sUserListGroup1)
{
Console.WriteLine("性别:{0},年龄总和:{1}", item.userSex, item.TotalAges);
} //5.2 根据用户性别进行分类,并且统计不同性别年龄的最大值
Console.WriteLine("-------------5.2 根据用户性别进行分类,并且统计不同性别年龄的最大值-------------------");
string sql2 = @"select userSex,MAX(userAge) as TotalAges
from Sys_UserInfor
group by userSex";
List<model3> sUserListGroup2 = ExecuteQuery<model3>(sql2);
foreach (var item in sUserListGroup2)
{
Console.WriteLine("性别:{0},年龄最大值:{1}", item.userSex, item.TotalAges);
}
}
#endregion

6. 分页用法
第十四节:Lambda、linq、SQL的相爱相杀(3)的更多相关文章
- 第十三节:Lambda、linq、SQL的相爱相杀(2)
一. Linq开篇 1.Where用法 linq中where的用法与SQL中where的用法基本一致. #region 01-where用法 { //1. where用法 //1.1 查询账号为adm ...
- 第十二节:Lambda、linq、SQL的相爱相杀(1)
一. 谈情怀 Lambda.Linq.SQL伴随着我的开发一年又一年,但它们三者并没有此消彼长,各自占有这一定的比重,起着不可替代的作用. 相信我们最先接触的应该就是SQL了,凡是科班出身的人,大学 ...
- 大白话5分钟带你走进人工智能-第十四节过拟合解决手段L1和L2正则
第十四节过拟合解决手段L1和L2正则 第十三节中, ...
- 第三百八十四节,Django+Xadmin打造上线标准的在线教育平台—路由映射与静态文件配置以及会员注册
第三百八十四节,Django+Xadmin打造上线标准的在线教育平台—路由映射与静态文件配置以及会员注册 基于类的路由映射 from django.conf.urls import url, incl ...
- 第三百七十四节,Django+Xadmin打造上线标准的在线教育平台—创建课程app,在models.py文件生成4张表,课程表、课程章节表、课程视频表、课程资源表
第三百七十四节,Django+Xadmin打造上线标准的在线教育平台—创建课程app,在models.py文件生成4张表,课程表.课程章节表.课程视频表.课程资源表 创建名称为app_courses的 ...
- 第三百六十四节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的mapping映射管理
第三百六十四节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的mapping映射管理 1.映射(mapping)介绍 映射:创建索引的时候,可以预先定义字 ...
- 第三百五十四节,Python分布式爬虫打造搜索引擎Scrapy精讲—数据收集(Stats Collection)
第三百五十四节,Python分布式爬虫打造搜索引擎Scrapy精讲—数据收集(Stats Collection) Scrapy提供了方便的收集数据的机制.数据以key/value方式存储,值大多是计数 ...
- 第三百四十四节,Python分布式爬虫打造搜索引擎Scrapy精讲—craw母版l创建自动爬虫文件—以及 scrapy item loader机制
第三百四十四节,Python分布式爬虫打造搜索引擎Scrapy精讲—craw母版l创建自动爬虫文件—以及 scrapy item loader机制 用命令创建自动爬虫文件 创建爬虫文件是根据scrap ...
- 第三百三十四节,web爬虫讲解2—Scrapy框架爬虫—Scrapy爬取百度新闻,爬取Ajax动态生成的信息
第三百三十四节,web爬虫讲解2—Scrapy框架爬虫—Scrapy爬取百度新闻,爬取Ajax动态生成的信息 crapy爬取百度新闻,爬取Ajax动态生成的信息,抓取百度新闻首页的新闻rul地址 有多 ...
随机推荐
- Zabbix 3.4.7调整监控阈值以及告警级别
1.找到需要监控的主机:右上角进行搜索 我们要更改sepm02p的阈值和级别: 进行更改级别:先点击Triggers , 选中要更改的监控项,例如我要更改CPU,点击以下红色标出的,千万不要选择Tem ...
- 洛谷 P1908 逆序对
\[传送门qwq\] 题目描述 猫猫\(TOM\)和小老鼠\(JERRY\)最近又较量上了,但是毕竟都是成年人,他们已经不喜欢再玩那种你追我赶的游戏,现在他们喜欢玩统计. 最近,\(TOM\)老猫查阅 ...
- Set.js--创建无重复值的无序集合
Set 集合,不同于 Array,是一种没有重复值的集合. 以下代码出自于<JavaScript 权威指南(第六版)>P217,注意:这里并不是指 es6 / es2015 中的 Set ...
- vue 2.0 + ElementUI构建树形表格
解决: 本来想在网上博客找一找解决方法,奈何百度到的结果都不尽人意,思维逻辑不清,步骤复杂,代码混乱,找了半天也没找到一个满意的,所以干脆就自己动手写一个 思路: table需要的数据是array,所 ...
- 图表插件Highcharts的动态化赋值,实现图表数据的动态化设置显示
在很早之前就介绍过图表插件Highcharts的使用了,在2014年的随笔<基于MVC4+EasyUI的Web开发框架经验总结(4)--使用图表控件Highcharts>,这里基本上都介绍 ...
- CentOS7.5脱机安装SQL Server 2017(NEW)
发现搜到的都是在线下载安装的,都是只安装了mssql-server服务,没有mssql-server-agent服务.还以为linux下mssql没有agent服务呢.一番测试发现可以脱机安装,但是能 ...
- ssh远程 和 上传/下载工具
常用的ssh远程工具有: putty : 软件体积小,开源免费. xshell : 功能强大,亦有免费试用版本 SecureCRT : 功能强大 ftp : 该软件用于上传下载文件 通过ssh ...
- thymeleaf循环
th:each属性用于迭代循环,语法:th:each="obj,iterStat:${objList}"迭代对象可以是Java.util.List,java.util.Map,数组 ...
- centos值cron-计划任务
一.crond简介 crond是Linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具.并且会自动启动cro ...
- springboot 静态注入 单例
package com.b2q.web_push.util; import io.goeasy.GoEasy; import org.springframework.beans.factory.ann ...