查询数据库中的数据

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. GOPS 2018全球运维大会上海站 参会感悟梳理

    今天遇到很多优秀的讲师.业界的大伽,很开心 现在把get到的信息梳理一下:(1)想解决性能问题,一定要在缓存上下功夫:[nginx上有好多文章可以做,真是博大精深呢<深入理解Nginx:模块开发 ...

  2. 1.字符串池化(intern)机制及拓展学习

    1.字符串intern机制 用了这么久的python,时刻和字符串打交道,直到遇到下面的情况: a = "hello" b = "hello" print(a ...

  3. SpringCloud的学习记录(5)

    这一章节讲如何使用ribbon和hystrix. 在我们生成的Demo项目上右键点击New->Module->spring Initializr, 然后next, 填写Group和Arti ...

  4. 构建跨平台APP开发的两本书,这里重点推荐下

    第一本是<构建跨平台:jquery Mobile移动应用实战> 是目前jqm开发写的比较入门的一本书,上手很快,但是高手我觉得就没有必要学习了,因为写的比较浅显. 第二本是<构建跨平 ...

  5. Javascript打印金字塔,倒立金字塔,空心金字塔,菱形,空心菱形等

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  6. express不是内部命令

    有时用npm install express -g安装完express时,在写express -v会显示express不是内部命令 这样的话如果自己的安装没有问题的话就要考虑到环境变量了 win7 P ...

  7. 写给future的话

    学习任何事务,永远不要被繁复的表象所迷惑. 觉得自己知识不够深,了解的不够多,其实就是思考感悟的不够罢了. 想,都是问题,做,才有答案 换位思考是人际交往最重要的能力之一.

  8. IOS 数据加密方式(加盐,MD5加密,)

    加密方式封装 @interface NSString (Hash) @property (readonly) NSString *md5String; @property (readonly) NSS ...

  9. 2017.9.21 HTML学习总结---多媒体播放系统设计

    1.题目:整个页面被划分三个子窗口,上面窗口为页面功能提示区, 下左部分为不同类型播放的功能选项,下右部分为播放系统显示播放信息窗口. (1)网页设计框架: <html> <head ...

  10. CNN中卷积的意义

    在传统的神经网络中,比如多层感知机(MLP),其输入通常是一个特征向量.需要人工设计特征,然后将用这些特征计算的值组成特征向量.在过去几十年的经验来看,人工找的特征并不总是好用.有时多了,有时少了,有 ...