SQL server数据查询笔记

数据查询

一、单表查询

二、连接查询

三、嵌套查询

四、集合查询

五、基于派生表的查询


一、单表查询

1.列查询

select [all|distinct] <表达式> [别名] [,<表达式> [别名]]...
from <表名|视图名> [,<表名|视图名>]...|(<select语句>) [as] <别名>
[where <条件表达式>]
[group by <列名1> [having <条件表达式>]]
[order by <列名2> [asc|desc]];

注:默认情况下select all

2.元组查询

  • 限定all或distinct
  • 增加where限定条件

where子句常用字符

查询条件 谓词 比较 =,>,<,>=,<=,!= 确定范围 between and,not between and 确定集合 in,not in 字符匹配 like,not like 空值 is null,is not null 逻辑运算 and,or,not

1.比大小

2.确定范围

between and包括两端的值

3.确定集合

       

4.字符匹配

格式:

[not] like '<匹配串>' [escape '<换码字符>']

%代表任意长度字符串,_代表任意单个字符

 

  • 聚集函数

聚集函数

count(*) 元组个数 count([all|distict] <列名>) 该列值个数 sum([all|distict] <列名>) 该列值综合 avg([all|distict] <列名>) 该列平均值 max([all|distict] <列名>) 该列最大值 min([all|distict] <列名>) 该列最小值

注:聚集函数只能用于select子句和group by的having子句中,默认为all

  • group by子句

作用:细化聚集函数的作用范围

 

3.order by


2.连接查询

  • 等值连接与非等值连接

等值连接:连接运算符为=

非等值连接:连接运算符不为=

连接查询的两种形式:

[<表1>.]<列名1> <比较运算符> [<表2>.]<列名2>
[<表1>.]<列1> between [<表2>.]<列2> and [<表2>.]<列3>

注:连接字段必须可比

Ex:查询选修2号课程且成绩在90分上所有学生的学号和姓名

注:先输入其他条件再输入连接条件执行效率更高 

  • 自身连接

EX:查询每一门课的先修课的先修课

  • 外连接

EX:查询每个学生的选课信息时,默认情况下要是有学生没选课,那么这个学生的信息就不显示了,现在要求把没选课的学生也显示出来

  • 多表连接

3.嵌套查询

查询块:一个select-from-where语句块

嵌套查询:查询块嵌入到另一个查询块的where或having子句中的查询

相关查询:子查询的查询条件依赖于父查询

不相关查询:子查询的查询条件不依赖于父查询

EX:查询和刘晨在同一个系中学习的学生

  • 使用in来完成嵌套查询
select Sno,Sname,Sdept
from Student
where Sdept in
    (
        select Sdept
        from Student
        where Sname='刘晨'
    );
  • 使用比较运算符来完成嵌套查询(得确切知道内层查询只有一个值了
select Sno,Sname,Sdept
from Student
where Sdept=
    (
        select Sdept
        from Student
        where Sname='刘晨'
    );

 EX:找出每个学生超过他自己选修课程平均成绩的课程号

select Sno,Cno
from SC x
where Grade>=
    (
        select avg(Grade)
        from SC y
        where y.Sno=x.Sno
    );

注:这里为了区分子查询和父查询中的SC,分别对SC取不同的别名来指示。

 

  • 带有any(some)all谓词的子查询

注:用聚集函数实现子查询比直接用any或all查询效率要高。

 

  • 带有exists谓词的子查询

注:

1.由exists引出的子查询,其目标列表达式通常用*,因为带exists的子查询只返回真或假值,给出列名无实际意义。

2.SQL中没有全称量词,只能用exists/not exists来代替。

 

EX:查询选修了全部课程的学生姓名

select Sname
from Student
where not exists
    (
        select *
        from Course
        where not exists
            (
                select *
                from SC
                where Sno=Student.Sno and Cno=Course.Cno
            )
    )

注:按照SQL没有全称量词的尿性,只能用没有一门课程是他不选修的来代替。

4.集合查询

集合操作:并(union)、交(intersect)、差(except)

 

5.基于派生表的查询

子查询不仅可以在where和having子句,也插入在from子句中,以此生成一个派生表并成为主查询的查询对象

EX:查询所有选修了1号课程的学生姓名

select Sname
from Student, (select Sno from SC where Cno='1') as SC1
where Student.Sno=SC1.Sno;

注:这里的as可以省略,SC1就是个派生表,现在SC1就可以当个普通的表来查询了

  • 3
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: SQL Server 备课笔记 SQL Server 是一种关系型数据库管理系统,用于存储和操作大量数据。备课笔记可以帮助教师们在备课过程中更好地组织和管理教学资源。 1. 数据库创建:使用 SQL Server Management Studio (SSMS) 创建一个新的数据库,可以选择数据库的名称和存储位置。创建数据库后,可以为数据库添加表格、视图、存储过程等对象。 2. 数据表设计:在数据库中创建数据表格时,需要定义表格的名称和列名,并为每列指定数据类型。可以使用 INT、VARCHAR、DATE 等各种数据类型来定义不同类型的数据。还可以定义主键、外键和索引,以提高查询性能和数据完整性。 3. 数据查询:使用 SQL 语句来查询数据库中的数据。常用的查询语句包括 SELECT、INSERT、UPDATE 和 DELETE。可以使用 WHERE 子句来过滤结果,ORDER BY 子句来排序结果,并使用 JOIN 子句来连接多个数据表格。 4. 数据修改:可以使用 INSERT 语句向数据表格中插入新的数据行,使用 UPDATE 语句修改现有的数据行,使用 DELETE 语句删除不需要的数据行。使用事务可以确保数据的一致性和完整性。 5. 数据备份和恢复:可以使用 SQL Server Management Studio 或 Transact-SQL 命令来备份和恢复数据库。备份操作可以将数据库的完整副本保存到硬盘或其他存储介质中,以便在发生故障时进行恢复。 总结:SQL Server 是一种强大的数据库管理系统,备课笔记可以帮助教师们更好地组织和管理教学资源。通过数据库的创建、数据表设计、数据查询数据修改以及数据备份和恢复等功能,可以有效地存储、操作和维护大量的教学数据,提高备课效率和教学质量。 ### 回答2: SQL Server是一种关系型数据库管理系统,在备课过程中使用它可以方便地存储学生信息、课程内容和成绩等数据,并且进行各种查询、统计和分析。 首先,在使用SQL Server进行备课时,可以创建一个名为“学生表”的表格,其中包含学生的学号、姓名、性别、年龄等字段。然后,通过SQL语句向该表格中插入学生信息。 在备课笔记中,可以利用SQL Server提供的创建表、插入数据和修改数据等功能来记录课程内容和教学进度。可以创建一个名为“课程表”的表格来存储课程信息,例如课程名称、授课教师、上课地点等字段。通过SQL语句向该表格中插入相应的课程信息。 此外,在备课过程中,还可以使用SQL Server查询功能来进行统计和分析。例如,可以使用SQL语句查询某门课程选修学生人数、平均成绩和考试成绩分布等信息。这些查询的结果可以用于制定备课计划和评估学生的学习情况。 此外,为了方便备课,可以在SQL Server中创建一个名为“备课笔记表”的表格,其中包含备课日期、备课内容、教学方法等字段。通过SQL语句向该表格中插入备课笔记,记录备课过程中的思考、想法和教学心得。 总之,SQL Server作为一种强大的数据库管理系统,可以在备课过程中提供存储、查询和分析数据的功能,从而帮助教师更好地备课和教学。在备课笔记中使用SQL Server可以方便地记录和管理备课过程中的相关信息。 ### 回答3: SQL Server备课笔记主要包括以下内容: 一、SQL Server的基础知识 1. SQL Server的概述:介绍SQL Server的定义、特点以及常见的版本。 2. SQL Server的体系结构:阐述SQL Server的组件和各个组件的作用。 二、SQL Server的安装与配置 1. SQL Server的安装:介绍SQL Server的安装步骤和注意事项。 2. SQL Server的配置:包括数据库引擎的配置、网络配置、安全性配置等。 三、SQL Server数据库管理 1. 数据库的创建与删除:介绍如何创建和删除数据库。 2. 数据库的备份与还原:介绍如何备份和还原数据库以及常见的备份策略。 3. 数据库的管理:包括数据库的扩展、缩小、文件组的管理等。 四、SQL Server数据操作 1. 创建和管理表:介绍创建表的语法和常见的表操作。 2. 数据的插入、更新和删除:介绍如何向表中插入、更新和删除数据。 3. 数据查询:介绍SQL Server查询语句以及常见的查询操作。 五、SQL Server的高级应用 1. 数据库的事务管理:介绍事务的概念、特性以及SQL Server中的事务相关操作。 2. 数据库的性能优化:包括索引的创建和管理、查询性能优化等。 六、SQL Server的安全性管理 1. 用户和权限管理:介绍如何创建和管理用户,并设置不同的权限。 2. 数据库的加密和解密:介绍如何对数据库进行加密和解密以保证数据的安全性。 七、SQL Server的监控与故障处理 1. 监控SQL Server的性能:介绍如何使用SQL Server的性能监视器来监控服务器的性能。 2. 故障处理:介绍如何处理常见的SQL Server故障,如数据库无法打开、死锁等。 通过学习SQL Server备课笔记,能够帮助我们全面了解SQL Server的基础知识、安装与配置、数据库管理、数据操作、高级应用、安全性管理以及监控与故障处理等方面的内容,提升我们的SQL Server应用能力和问题解决能力。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值