【SQL Server】查询和汇总数据库的数据

主要内容

1.使用SELECT语句进行单表查询、多表查询、连接查询、集合查询

2.使用聚合函数查询

3.使用GROUP BY子句对查询结果进行分组

4.使用HAVING子句对查询结果的分组进行筛选

5.  使用ORDER BY子句对查询结果按照一个或多个属性列的值的升序或降序实现排序


1)使用SELECT语句进行单表查询、多表查询、连接查询、集合查询:

Step 1 打开SMSS,使用前面创建好的数据库S_C_SC;


Step 2 进行单表查询

--查询全体学生的学号与姓名。

SELECT Sno,Sname   FROM Student;

--查询经过计算的值(学生出生年份)

SELECT   Sname,2022-Sage   FROM Student;

发现无列名,修改T-SQL语句,赋列名为“birth”:

--查询经过计算的值(学生出生年份)

SELECT   Sname,2022-Sage as 'birth'   FROM Student;

Where子句下的单表查询:

--使用where子句对单表进行条件查询

--查询不是计科系、信息系的学生的姓名、学号和性别。

 SELECT Sname, Sno, Ssex     FROM Student      WHERE Sdept NOT IN ('IS','CS');

Step 3 进行多表查询

--多表查询

SELECT Student.Sname, Student.Sno, Course.Cname, SC.Grade

FROM Student, Course, SC

发现,Student表、Course表与SC表之间涉及到的所有数据均相连,导致数据无效,深究发现这是产生了笛卡尔积

Step 4 进行连接查询

连接查询分为等值连接、非等值连接和自身连接

下面进行等值连接查询

--等值连接查询

SELECT  Student.*, Course.*, SC.*

FROM  Student, Course, SC

WHERE  Student.Sno = SC.Sno

AND Course.Cno = SC.Cno

将上述等值连接查询中的重复列去除,便是自然连接

--自然连接

SELECT  Student.Sno,Sname,Ssex,Sage,Sdept,Grade, Course.Cno,Cname,Cpno,Ccredit, SC.Grade

FROM  Student, Course, SC

WHERE  Student.Sno = SC.Sno

AND Course.Cno = SC.Cno

从这里可以发现,在Step 3中多表查询时,Student表、Course表与SC表之间的所有数据均相连,导致数据无效,但是在此处的等值查询中引入了连接条件,便没有出现所有数据相连的情况;由此可见,笛卡尔积的产生条件是省略了连接条件或连接条件无效,这同样也告诉我们,在多表查询时,表间有相同的字段,才好进行有效的多表查询。

使用非等值连接查询选修信息系统课程并成绩高于85分的学生信息:

--非等值连接查询

--查询选修信息系统课程并成绩高于85分的学生信息

SELECT Student.Sno, Sname   

FROM Student, SC

WHERE Student.Sno = SC.Sno

AND SC.Cno = 3

AND SC.Grade > 85;

在本次查询中,主要引入了成绩大于85这一条非等值的查询条件,构建了一个非等值查询。

使用自身连接查询间接先修课:

--自身连接

--查询间接先修课

SELECT FIRST.Cno,  SECOND.Cpno, THIRD.Cname, FOURTH.Cname

FROM Course FIRST, Course SECOND, Course THIRD, Course FOURTH 

WHERE FIRST.Cpno = SECOND.Cno

AND FIRST.Cno = THIRD.Cno

AND SECOND.Cpno = FOURTH.Cno

Step 4 进行集合查询

集合查询分为并查询与交查询,其中并操作UNION是将多个查询结果合并起来时,并且系统自动去掉重复元组(UNION ALL:不去除重复元组),其中交操作INTERSECT指“既......又......”(连接的查询是不同属性时可转换为AND连接);

需要注意的是,参加集合操作的各查询结果的列数必须相同,对应项的数据类型也必须相同

并查询:

--集合查询-并查询

--查询选修了课程1或者选修了课程2的学生

SELECT SC.Sno, Student.Sname

FROM SC, Student

WHERE Cno = 1

AND SC.Sno = Student.Sno

UNION

SELECT SC.Sno, Student.Sname

FROM SC, Student

WHERE Cno = 2

AND SC.Sno = Student.Sno;

交查询:

---交查询

--查询既是数学系的学生年龄又不大于19岁的学生

SELECT *  FROM Student 

WHERE Sdept='MA' 

INTERSECT 

SELECT * FROM Student

WHERE Sage <= 19;

2)使用聚合函数查询

--聚合函数

--查询每个专业最大的年龄

SELECT Sdept, MAX(Sage)oldest_age

FROM Student

GROUP BY Student.Sdept

ORDER BY oldest_age;

--计算各个课程成绩的平均分

SELECT Cno, AVG(Grade)AVG_G

FROM SC

GROUP BY SC.Cno

ORDER BY AVG_G DESC;

在上述操作中,我使用聚合函数中的MAX与AVG函数分别查询了每个专业最大的年龄和各个课程成绩的平均分;

并使用GROUP BY子句对查询结果进行分组,其中查询年龄一例中是采取基于专业名(CS、IS、MA)进行分组,而查询平均分一例中是采取基于课程序号进行分组;

此外,我还使用了ORDER BY子句分别对上述两例按照年龄升序和平均分降序进行排列。

3)进一步使用GROUP BYHAVING以及ORDER BY子句对查询结果进行整理

--聚合函数进阶

--查询各专业平均已成年的班级内年龄最小的女生年龄

SELECT Sdept as Sdept_girl, MIN(Sage)youngest_age

FROM Student

WHERE Ssex = '女'

GROUP BY Sdept

HAVING AVG(Sage) >= 18

ORDER BY youngest_age

上述操作中,我使用聚合函数中的MIN函数,以及WHERE子句、GROUP BY子句、HAVING子句以及ORSER BY子句,实现了查询各专业平均已成年(年龄大于18岁)的班级内年龄最小的女生的具体年龄。

其中,WHERE子句实现了筛选出女生行,GROUP BY实现了基于专业进行分组,HAVING子句实现了在分组内筛选出平均年龄大于18岁的组(专业),最后的ORDER BY子句实现了基于最小年龄的升序排列。


总结

本文主要对基于SQL数据库的查询与数据整理汇总等操作进行初学演示,展示了单表查询、多表查询、连接查询和聚合查询多种查询方式,并且使用聚合函数计算、统计、汇总、检索结果,熟悉了多种查询条件的设置。

需要注意的是——使用GROUP BY子句进行查询结果的分组,使用ORDER BY子句以及其ASC关键字或DESC关键字对查询的数据进行升序或降序排列,使用WHERE子句对待查询数据进行筛选,使用HAVING子句对查询所得的分组进行筛选。

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: c#是一种面向对象的编程语言,可以通过它来操作SQL Server数据库进行查询。 首先,我们需要使用C#中的System.Data.SqlClient命名空间来连接和操作SQL Server数据库。我们可以使用SqlConnection类来打开连接,并且传入数据库连接字符串作为参数。 接下来,我们可以使用SqlCommand类来执行SQL查询语句。可以使用ExecuteReader方法来执行SELECT语句,并返回一个SqlDataReader对象,该对象包含查询结果。我们可以通过调用SqlDataReader的Read方法来读取每一行的数据,并使用相应的索引或列名来获取特定列的值。 例如,我们可以使用以下代码来查询一个名为"Students"的表,并输出所有学生的姓名: ``` using System; using System.Data.SqlClient; class Program { static void Main() { string connectionString = "Data Source=server_name;Initial Catalog=database_name;User ID=user_id;Password=password"; using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); string query = "SELECT Name FROM Students"; using (SqlCommand command = new SqlCommand(query, connection)) { using (SqlDataReader reader = command.ExecuteReader()) { while (reader.Read()) { string name = reader.GetString(0); Console.WriteLine(name); } } } } } } ``` 在上面的代码中,我们首先定义了一个连接字符串,它包含连接到SQL Server数据库所需的信息。然后我们使用using语句创建一个SqlConnection对象,并传入连接字符串来打开连接。 接下来,我们定义了一个查询语句,该语句选择了Students表中的所有姓名列。然后我们使用using语句创建一个SqlCommand对象,并传入查询语句和SqlConnection对象。最后我们使用ExecuteReader方法执行查询,并使用SqlDataReader的GetString方法来获取姓名列的值。然后我们使用Console.WriteLine方法将其输出。 注意在连接数据库时,需要替换连接字符串中的server_name、database_name、user_id和password为相应的信息。 以上就是使用C#进行SQL Server数据库查询的简单示例。当然,还有更多的方法和技巧可以进行数据库查询,这只是一个简单的入门指南。 ### 回答2: c sql server数据库查询是一种用于从SQL Server数据库中获取数据的操作。它通过编写SQL查询语句来实现这一目标。查询可以用于检索数据、过滤数据、排序数据以及汇总数据等。 一般而言,一个SQL查询包括以下几个部分:选择(select)、条件(where)、排序(order by)和限制(limit)。选择部分定义了要检索的列,条件部分过滤了要检索的行,排序部分定义了检索结果的排序方式,而限制部分则限制了检索结果的数量。 SQL查询可以根据特定的条件来过滤数据。例如,我们可以使用WHERE子句来指定一些特定的条件,比如只检索年龄大于18的学生,或者只检索姓名以'A'开头的员工等等。 排序在查询中也非常重要,它可以让我们按照指定的列对结果进行升序或降序的排列。例如,我们可以使用ORDER BY子句按照员工的工资从高到低对员工进行排序。 限制部分用于限制检索结果的数量。我们可以使用LIMIT关键字来设定需要返回的记录数,通过这个方式可以避免一次检索返回过多的数据,提高查询性能。 除了基本的查询操作,SQL还提供了许多高级的查询功能,如连接(join)、分组(group by)、统计函数和子查询等等。这些功能可以帮助我们更加灵活和高效地处理复杂的数据查询需求。 总之,c sql server数据库查询是一种利用SQL语言对SQL Server数据库进行检索、过滤、排序等操作的技术。它为我们提供了便利的方式来从数据库中获取需要的数据,并且可以根据具体需求进行灵活的查询设计。 ### 回答3: SQL Server是一种关系型数据库管理系统,用于存储、管理和查询数据。它提供了一种称为结构化查询语言(SQL)的编程语言,允许用户执行各种操作,包括创建表、插入、删除和更新数据以及查询数据。 在SQL Server中,查询是指在数据库中检索所需的数据。用户可以使用SELECT语句来执行查询操作。SELECT语句由一系列关键字和表达式组成,用于指定要返回的数据列、表、条件和排序方式。 SQL Server查询语句可以使用WHERE子句来限制返回的数据行。WHERE子句使用用于比较的运算符,例如等于(=)、不等于(<>)、大于(>)、小于(<)等。可以使用AND和OR运算符来组合多个条件。WHERE子句还可以与通配符(如LIKE)一起使用,以便模糊搜索数据。 此外,SQL Server还提供了其他用于查询的关键字和函数。例如,GROUP BY子句用于将结果按指定的列进行分组,并使用聚合函数(如SUM、AVG、MAX和MIN)计算每个组的汇总值。HAVING子句通常与GROUP BY一起使用,用于筛选分组后的结果。 在查询中,还可以使用ORDER BY子句对返回的数据进行排序。可以指定要按升序(ASC)或降序(DESC)排序的列。ORDER BY子句通常在SELECT语句的末尾使用。 综上所述,SQL Server数据库查询是指使用SQL语句在数据库中检索所需数据的过程。通过使用SELECT、WHERE、GROUP BY、HAVING和ORDER BY等关键字和函数,用户可以根据特定条件检索数据、进行分组和聚合,并按照指定的排序方式返回结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值