查询数据库中的数据

from… in子句

指定查询操作的数据源和范围变量

select子句

指定查询结果的类型和表现形式

where子句

筛选元素的逻辑条件,一般由逻辑运算符组成

group… by子句

对查询进行分组

order  by子句

对查询结果进行排序,可以为“升序”或“降序”

join子句

连接多个查询操作的数据源

let子句

引入用于存储查询表达式中的子表达式结果的范围变量

into子句

提供一个临时标示符,充当对join、group或select子句的结果

一、from… in子句

以下例子均使用此数据库

USE master -- 设置当前数据库为master,以解除对Students的占用
GO
IF EXISTS(SELECT * FROM sys.databases WHERE name='Students')
DROP DATABASE Students --创建一个Students数据库
CREATE DATABASE Students GO GO
IF EXISTS(SELECT * FROM sys.sysobjects WHERE xtype = 'U' AND name='StuInfo')
DROP TABLE StuInfo USE Students -- 设置当前数据库为Students
CREATE TABLE StuInfo
(
-- 创建学生信息表
StuID int NOT NULL PRIMARY KEY, -- 学生学号,主键
StuName varchar(10) NOT NULL, -- 学生姓名,非空
StuSex char(2) NOT NULL DEFAULT('男'), -- 学生性别,非空
CHECK (StuSex ='男' or StuSex='女' )
)
GO GO
IF EXISTS(SELECT * FROM sys.sysobjects WHERE xtype = 'U' AND name='StuMarks')
DROP TABLE StuMarks USE Students -- 设置当前数据库为Students
CREATE TABLE StuMarks
(
-- 创建学生成绩表
ExamNo int identity(1,1) primary key, -- 考试编号,标识
StuID int NOT NULL references StuInfo(StuID), -- 考生学号,外键
Course varchar(10) not null, -- 考试科目
Score int default(0), -- 考试成绩
)
GO GO
USE Students -- 设置当前数据库为Students
INSERT INTO StuInfo (StuID,StuName,StuSex)
SELECT 1,'张三','男' UNION
SELECT 2,'李四','男' UNION
SELECT 3,'钱七','女' UNION
SELECT 4,'王五','女' UNION
SELECT 5,'赵六','男'
GO GO
USE Students -- 设置当前数据库为Students
INSERT INTO StuMarks (StuID,Course,Score)
SELECT 1,'语文',70 UNION
SELECT 1,'数学',89 UNION
SELECT 2,'语文',33 UNION
SELECT 2,'数学',50 UNION
SELECT 3,'语文',79 UNION
SELECT 3,'数学',90 UNION
SELECT 4,'语文',88 UNION
SELECT 4,'数学',74 UNION
SELECT 5,'语文',64 UNION
SELECT 5,'数学',92
GO GO
SELECT * FROM StuInfo;
SELECT * FROM StuMarks;

FROM...IN子句

 protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataClasses1DataContext dc = new DataClasses1DataContext(); Response.Write("<br/>查询数据库<br/>");
var stus1 = from stu in dc.StuInfos
select stu;
foreach (var stu in stus1)
{
Response.Write(stu.StuID + "、" + stu.StuName + "、" + stu.StuSex + "<br/>");
} Response.Write("<br/>查询对象<br/>");
List<int> datas = new List<int> { 1, 3, 5, 7, 9 };
var stus2 = from data in datas
select data; foreach (var stu in stus2)
{
Response.Write(stu + "<br/>");
}
}
}

运行的结果如下:

二、select子句

 protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataClasses1DataContext dc = new DataClasses1DataContext(); Response.Write("<br/>分组查询所有男学生和女同学的信息<br/>");
var stus1 = from stu in dc.StuInfos
group stu by stu.StuSex;
foreach (var groups in stus1)
{
Response.Write("<br/>分组名称:" + groups.Key + "<br/>");
foreach (var stu in groups)
{
Response.Write(stu.StuID + "、" + stu.StuName + "<br/>");
}
} Response.Write("<br/>分组查询所有男学生的信息<br/>");
var stus2 = (from stu in dc.StuInfos
group stu by stu.StuSex).ToList(); foreach (var stu in stus2.ElementAt(0))
{
Response.Write(stu.StuID + "、" + stu.StuName + "<br/>");
}
}
}

运行的结果:

三、where子句

 protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataClasses1DataContext dc = new DataClasses1DataContext(); Response.Write("<br/>查询所有男学生信息<br/>");
var stus1 = from stu in dc.StuInfos
where stu.StuSex == "男"
select stu;
foreach (var stu in stus1)
{
Response.Write(stu.StuID + "、" + stu.StuName + "<br/>");
} Response.Write("<br/>查询所有姓张的男学生信息<br/>");
var stus2 = from stu in dc.StuInfos
where stu.StuSex == "男" && stu.StuName.StartsWith("张")
select stu;
foreach (var stu in stus2)
{
Response.Write(stu.StuID + "、" + stu.StuName + "<br/>");
}
}
}

运行的结果:

四、group … by子句

 protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataClasses1DataContext dc = new DataClasses1DataContext(); Response.Write("<br/>分组查询所有男学生和女同学的信息<br/>");
var stus1 = from stu in dc.StuInfos
group stu by stu.StuSex;
foreach (var groups in stus1)
{
Response.Write("<br/>分组名称:" + groups.Key + "<br/>");
foreach (var stu in groups)
{
Response.Write(stu.StuID + "、" + stu.StuName + "<br/>");
}
} Response.Write("<br/>分组查询所有男学生的信息<br/>");
var stus2 = (from stu in dc.StuInfos
group stu by stu.StuSex).ToList(); foreach (var stu in stus2.ElementAt(0))
{
Response.Write(stu.StuID + "、" + stu.StuName + "<br/>");
}
}
}

运行结果为:

五、orderby子句

 protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataClasses1DataContext dc = new DataClasses1DataContext(); Response.Write("<br/>降序查询所有学生的成绩信息<br/>");
var marks1 = from mark in dc.StuMarks
orderby mark.Score descending
select mark;
foreach (var mark in marks1)
{
Response.Write(mark.StuID + "、" + mark.Course + "、" + mark.Score + "<br/>");
} Response.Write("<br/>降序查询所有学生的数学成绩信息<br/>");
var marks2 = from mark in dc.StuMarks
where mark.Course=="数学"
orderby mark.Score descending
select mark;
foreach (var mark in marks2)
{
Response.Write(mark.StuID + "、" + mark.Score + "<br/>");
}
}
}

运行结果为:

六、join子句

  protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataClasses1DataContext dc = new DataClasses1DataContext(); Response.Write("<br/>查询所有学生的姓名及考试信息<br/>");
var res1 = from stu in dc.StuInfos
join mark in dc.StuMarks
on stu.StuID equals mark.StuID
select new { stu.StuName,mark.Course,mark.Score}; foreach (var stu in res1)
{
Response.Write(stu.StuName + "、" + stu.Course + "、" + stu.Score + "<br/>");
} Response.Write("<br/>查询所有学生的姓名及考试信息<br/>");
var res2 = from stu in dc.StuInfos
from mark in dc.StuMarks
where stu.StuID == mark.StuID
select new { stu.StuName, mark.Course, mark.Score }; foreach (var stu in res2)
{
Response.Write(stu.StuName + "、" + stu.Course + "、" + stu.Score + "<br/>");
}
} }

运行结果为:

七、let子句

 protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataClasses1DataContext dc = new DataClasses1DataContext(); Response.Write("<br/>查询所有姓张的男学生信息<br/>");
var stus1 = from stu in dc.StuInfos
let start = stu.StuName.StartsWith("张")
where stu.StuSex == "男" && start //== true
select stu;
foreach (var stu in stus1)
{
Response.Write(stu.StuID + "、" + stu.StuName + "<br/>");
}
}
}

运行结果为:

八、into子句

protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
DataClasses1DataContext dc = new DataClasses1DataContext(); Response.Write("<br/>分组查询所有男学生和女同学的信息<br/>");
var stus1 = from stu in dc.StuInfos
group stu by stu.StuSex into res
select res;
foreach (var groups in stus1)
{
Response.Write("<br/>分组名称:" + groups.Key + "<br/>");
foreach (var stu in groups)
{
Response.Write(stu.StuID + "、" + stu.StuName + "<br/>");
}
}
}
}

运行结果为:

Linq to SQL八大子句的更多相关文章

  1. 年终巨献 史上最全 ——LINQ to SQL语句

    LINQ to SQL语句(1)之Where 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句.Where操 ...

  2. LINQ to SQL语句(18)之运算符转换

    运算符转换 1.AsEnumerable:将类型转换为泛型 IEnumerable 使用 AsEnumerable<TSource> 可返回类型化为泛型 IEnumerable 的参数.在 ...

  3. Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等)

    Linq to SQL 语法查询(链接查询,子查询 & in操作 & join,分组统计等) 子查询 描述:查询订单数超过5的顾客信息 查询句法: var 子查询 = from c i ...

  4. LINQ to SQL语句(9)之Top/Bottom和Paging和SqlMethods

    适用场景:适量的取出自己想要的数据,不是全部取出,这样性能有所加强. Take 说明:获取集合的前n个元素:延迟.即只返回限定数量的结果集. var q = ( from e in db.Employ ...

  5. LINQ TO SQL 大全

    最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精 LINQ to SQL语句(1)之Where 适用场景: ...

  6. Linq to sql 的语法

    Linq to SQL 语法查询(子查询 & in操作 & join ) 引用地址:http://www.cnblogs.com/82767136/articles/2949541.h ...

  7. LINQ to SQL Count/Sum/Min/Max/Avg Join

    public class Linq { MXSICEDataContext Db = new MXSICEDataContext(); // LINQ to SQL // Count/Sum/Min/ ...

  8. LINQ to SQL大全

    LINQ to SQL语句 (1)之Where Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的 ...

  9. [转]LINQ To SQL 语法及实例大全

    转载自:http://blog.csdn.net/pan_junbiao/article/details/7015633 LINQ to SQL语句(1)之Where Where操作 适用场景:实现过 ...

随机推荐

  1. 【防火墙】DMZ

    DMZ是英文“demilitarized zone”的缩写,中文名称为“隔离区”,也称“非军事化区”.它是为了解决安装防火墙后外部网络的访问用户不能访问内部网络服务器的问题,而设立的一个非安全系统与安 ...

  2. Oracle错误——ORA-03113:通信通道的文件结尾

    请参考:http://blog.csdn.net/zwk626542417/article/details/39667999 今天跟往常一样,登陆PL/SQL,确登陆失败,出现一个错误“ORA-010 ...

  3. js中各种距离clientWidth

    1: offsetLeft.offsetTop.offsetHeight.offsetWidth 1.1 偏移参照——定位父级offsetParent   offsetParent的定义是:与当前元素 ...

  4. rem与em的区别

    这两个单位都是相对元素 rem相对根元素 em相对于父级元素

  5. 测试驱动开发(TDD)及测试框架Mocha.js入门学习

    组里马上要转变开发模式,由传统的开发模式(Developer开发,QA测试),转变为尝试TDD(Test-driven development,测试驱动开发)的开发模型.由此将不存在QA的角色,或者仅 ...

  6. python 不同目录间的模块调用

    有时候调用的模块不再同一个目录.直接import 是加载不进来的.默认的加载路径是sys.path中指定的路径.如果要指定加载的目录得需要把这个目录加到sys.path里面. 比如要加载父目录的同级目 ...

  7. sharepoint2010列表的分页实现迅雷样式效果

    利用ListItemCollectionPosition和AspNetPage分页控件实现,效果图如下: 后台分页代码如下: #region 私有方法 /// <summary> /// ...

  8. X-Cart-5.3.1.4 (Ubuntu 16.04)

    平台: Ubuntu 类型: 虚拟机镜像 软件包: x-cart-5.3.1.4 commercial ecommerce open-source x-cart 服务优惠价: 按服务商许可协议 云服务 ...

  9. Office加载项对Excel进行读写操作

    转载自我的个人主页 前言 在开发ExcelWeb插件的时候,一大亮点就是可以在web项目中操作Excel,读取Excel的内容,也可以将服务端的数据写入的 Excel中,大大方便的用户使用Excel, ...

  10. Win10桌面右键响应非常慢怎么办?

    Win10桌面右键响应非常慢怎么办? 或许所有人升级到Win10都可能会遇上一个共同问题,右键桌面弹出菜单的反应非常非常的慢,你也感觉到了吧.在桌面点个右键需要等待五六秒左右的时间,这到底是不是系统问 ...