1 SQL快速入门、查询(SqlServer)[郝斌SqlServer完整版]

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: 系统数据库:master、model、msdb、tempdb【我们自定义数据库的管理维护运行都需要系统库支持】

💡 根据郝斌老师视频教程,整理学习笔记内容实用,完整全面;

视频 郝斌-SQLserver教程
作者 郝斌
状态 已学完
简介 zinksl学习笔记;快速掌握查询相关的基本操作,内容完整实用


SQL学前导图


16.jpg

:::info

系统数据库:master、model、msdb、tempdb【我们自定义数据库的管理维护运行都需要系统库支持】

:::


一 、基本信息


1 相关名词


数据库相关基本概念:字段、属性、记录(元祖)、表、主键、外键

名称 说明
字段 记录事物某一特征
记录 同一事物多个字段的组合,表示某一事物
多条记录的组合,表示同类事物
主键 唯一标识某一事物的一个属性
外键 此字段:来自另一个表的主键

表之间多对一时:外键建在"多"表中


2 基本语句


-- 创建表案例
create table table1
(
--  |字段|类型|约束    |约束名  |主键 
  t_id int constraint t_pk primary key,
  t_name varchar(20) not null,
  t_age int not null,
  t_sex varchar(1)
)
create table table2
(
  t2_id int constraint t2_pk primary key,
  t2_name varchar(15) not null,
--  |字段|类型 |约束    |约束名  |外键     |涉及到     |表名
  t1_id int constraint t2_fk foreign key references table1
)


3 约束:主键约束、外键约束、check约束、default约束、唯一约束


定义:

对于表中某字段,操作的限制

:::info

主键约束:不允许重复的记录添加,避开了数据冗余;(主体完整性)

外键约束:通过外键约束,从语法上保证了与此关联的事物是存在的(引用完整性)

check约束:保证字段取值在合法范围内

default约束:保证字段一定有一个值

unique约束:保证数据唯一性【主键与唯一约束的区别:唯一约束可为有空】

:::

某张表中多个字段组合作主键

主键: 能够唯一标示一个事物的一个字段或者多个字段的组合,被称为主键

含有主键的表叫做主键表

主键通常都是整数 不建议使用字符串当主键(如果主键是用于集群式服务)

主键的值通常都不允许修改,除非本记录被删除

多对多表查询中,必须借助第三张表;

constraint t_pk primary key(字段1,字段2,字段3)

二、查询


查询相关: 计算列、distinct、between、in、top、null、order by 、模糊查询、聚合函数、group by、having、链接查询、嵌套查询

select 语句执行顺序

第一步:查看来自哪张表(from)

第二步:查看查询字段【如果是表中字段则输出相关字段】 如果是其他值则输出与表格对应行数的值


1 计算列


在查询语句中,可以对字段进行算术运算

select ename, sal*12 as "年薪" from emp

2 distinct(去重)


会过滤掉重复的任意值【包括null】

-- 过滤重复字段
select distinct deptno as "部门编号" from emp

3 between


限定取值范围;between需要配合where一起使用

-- between的使用 查询sal在800-1500之间的值【包含两端】
select sal from emp 
where  sal between 800 and  1500


4 in包含


取值为in里面的值

-- 只取in内值
select sal from emp 
where sal in(800,1500)
-- 只取in外的值
select sal from emp 
where sal not in(800,1500)


5 top 分页【取前几个值】

-- 取所有sal中的前两个值
select top 2 sal from emp

案例

-- 输出工资在1500-3000之间工资最高的前四个人姓名工资
select top 4 ename,sal from emp
where sal between 1500 and 3000
order by sal desc


6 null


null不能参与数学运算,否则值为空

isnull()函数

isnull(a,b):如果不为空则值取a,否则取b

-- 输出前四个人年薪和基本信息
 select top 4 *,sal*12 + ISNULL(comm,0) from emp


7 order by 排序


排序:order by 排序【默认升序】

asc:升序

desc:降序

① order by A,B

先按照A升序排序,再将A相同的B升序排序

② order by A desc, B

A降序排序,再将A相同的B升序排序

③ order by A desc, B,C,D

对A降序排序,不会对BCD产生影响

④ order by A,B desc

先按A升序,再按A相同的B降序

-- 查询姓名和工资,以工资降序排列
select  ename,sal from emp
order by sal desc
-- 查询各部门姓名和


8 模糊查询


基本格式:select 字段名 from 表名 where 字段名 like 匹配条件

单引号和双引号的区别:单引号表示字符串,双引号表示标识符(变量 函数等的名字)

匹配条件:需要用单引号‘’括起来

% :任意一个或多个字符

_ : 任意单个字符

[a-f]: 匹配从a-f任意单个包含a和f

[a,f]:匹配a和f任意单个

[^a-f]:匹配不是a-f的其他任意单个字符

-- 在员工表中查询所有名字以A开头的人名
select ename from emp  where ename like 'A%'
-- 在员工表中查询所有名字以A-F开头的人名
select ename from emp  where ename like '[A-F]%'
-- 在员工表中查询所有名字以A或F开头的人名
select ename from emp  where ename like '[A,F]%'
-- 在员工表中查询所有名字不以A-F开头的人名
select ename from emp  where ename like '[^A-F]%'

转义字符 【escape ‘\’】

在SQLserver中我们可以通过escape 定义任意符号为:转义字符

-- 搜索名字中带有%的内容
select name from student where name like '%\%%' escape '\'


三、聚合函数


单行函数和多行函数不能混合使用

1.jpg


count()

(1)为空(null)的记录不会被统计

-- 统计emp表中所有记录数
select count(*) from emp
-- 统计emp表中所有人名
select count(ename) from emp


四、分组 group by


理解:group by a,b,c的用法先按a分组,如果a相同,再按b分组,如果b相同,再按c分组最终统计的是最小分组的信息


having对分组后的数据进行过滤

综合案例

select deptno, job,count(*) from emp 
where sal > 1000
group by deptno,job
having count(*) > 1


五、链接查询(多表查询)


2.jpg

内链接:


(1)select … from A,B

(2)select … from A,B where …

(3)select … from A join B on …

(4)select … from A,B

--1.求出每个员工的姓名 部门编号 薪水 和 薪水的等级
select S.grade
from emp "E" 
join salgrade "S" 
on E.sal<=S.hisal and E.sal>=S.losal 
--2.查找每个部门的编号 该部门所有员工的平均工资 平均工资的等级
select T.dno,S.grade,T.avg_sal
from(select D.deptno as "dno",AVG(sal) as "avg_sal"
from emp "E" join dept "D" on E.deptno = D.deptno 
group by D.deptno) "T" join salgrade "S"  on T.avg_sal >= S.losal and T.avg_sal<= S.hisal
--3.求出emp表中所有领导的姓名
select ename from emp
where empno in(select mgr from emp)
--4.求出平均薪水最高的部门的编号和部门的平均工资
select T.deptno,D.dname,T.avg_sal from 
(select deptno,AVG(sal) as "avg_sal"
from emp group by deptno) "T" join dept "D" on T.deptno = D.deptno
--5.把工资大于所有员工平均工资最低的前3个人的姓名 工资 部门编号输出
select top 3 E.ename,E.sal,E.deptno,D.dname 
from emp "E" join dept "D" on E.deptno = D.deptno
where E.sal > (select AVG(sal) from emp )
order by sal asc


外链接


定义:不但返回满足连接条件的所有记录,而且会返回部分不满足条件的记录

(1)左外链接

用左表的第一行分别和右表的所有行进行联接,如果有匹配的行,则一起输出,如果右表有多行匹配,则结果集输出多行,如果没有匹配行,则结果集中只输出一行,该输出行左边为左表第一行内容,右边全部输出null

然后再用左表第二行和右边所有行进行联接,如果有匹配的行,则一起输出,如果右表有多行匹配,则结果集输出多行,如果没有匹配行,则结果集中只输出一行,该输出行左边为左表第二行内容,右边全部输出null

以此类推,直至左边所有行连接完毕

因为右边很可能出现有多行和左边的某一行匹配,所以左联接产生的结果集的行数很可能大于leftjoin 左边表的记录的总数

左向外联接的结果集包括LEFTOUTER子中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行则在相关联的结果集行中右表的所有选择列表列均为空值。

实际意义:返回一个事物及其该事物的相关信息,如果该事物没有相关信息,则输出null

(2)右外链接

与左链接相同


自连接


--在不使用聚合函数的情况下,查询工资最高的人员信息
select * from emp "E"
where E.sal not in (select E1.sal from emp "E1" join emp "E2" on E1.sal < E2.sal)


联合的用法【union】


联合:是将两个表纵向合并

-- 联合的使用
select emp.ename,emp.sal,E.ename "上级名称" 
from emp join emp "E"
on emp.mgr = E.empno
union select ename ,sal,'boss'
from emp where mgr is null

联合注意事项:

①联合中的列数 需要与查询列数一致

②联合列的数据类型需要与查询数据列数据类型兼容


六 分页查询【top只有SqlServer有】


公式:

假设每页显示n条记录,当前要显示的是第m页表名是A 主键是A_id

**select top n ***

from A

*where A_id not in (select top (m-1)n A_id from A)

案例:

-- 分页查询每页显示4人信息(按照工资降序)
--1-3
select top 3 * from emp
order by sal desc
-- 4-6
select top 3 * from emp
where empno not in(select top 3 empno from emp
order by sal desc)
order by sal desc
-- 7-9
select top 3 * from emp
where empno not in(select top 6 empno from emp
order by sal desc)
order by sal desc
-- 10-12
select top 3 * from emp
where empno not in(select top 9 empno from emp
order by sal desc)
order by sal desc
-- 13-14
select top 3 * from emp
where empno not in(select top 12 empno from emp
order by sal desc)
order by sal desc


identity关键字:主键自动增长;【当被删除一个数据后:会打断主键连续自增】

create table tableT
(
  empid int identity(1, 1),
  ename nvarchar(20) not null
)
-- 插入数据
insert into tableT values ('aaaa');
insert into tableT values ('bbbb');
insert into tableT values ('cccc');
insert into tableT values ('dddd'); 
 --删除empid为4的记录select* from emp
delete from tableT delete from emp where empid =4
--因为执行delet时empid为4,所以下一句插入时empid会从5开始
insert into tableT values('eeee') 
delete from tableT where empid = 5
dbcc checkident('tableT',reseed,3) --此行把emp表中identity字段的初始值重新设置为3
insert into tableT values('eeee') --此时插入记录时,empid为4,上一行已经把empid设置成了3
select* from emp

学习思维:

3.png


七 视图:


视图可以作为一个临时表处理:可以简化查询

-- 视图操作
 --创建vs1视图
 CREATE VIEW vs1
  AS SELECT ename,deptno FROM emp
 -- 使用视图vs1查数据
  select sal from vs1
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
19天前
|
SQL NoSQL Java
Java使用sql查询mongodb
通过使用 MongoDB Connector for BI 和 JDBC,开发者可以在 Java 中使用 SQL 语法查询 MongoDB 数据库。这种方法对于熟悉 SQL 的团队非常有帮助,能够快速实现对 MongoDB 数据的操作。同时,也需要注意到这种方法的性能和功能限制,根据具体应用场景进行选择和优化。
64 9
|
1月前
|
SQL 存储 人工智能
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
Vanna 是一个开源的 Python RAG(Retrieval-Augmented Generation)框架,能够基于大型语言模型(LLMs)为数据库生成精确的 SQL 查询。Vanna 支持多种 LLMs、向量数据库和 SQL 数据库,提供高准确性查询,同时确保数据库内容安全私密,不外泄。
148 7
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
|
2月前
|
SQL Java
使用java在未知表字段情况下通过sql查询信息
使用java在未知表字段情况下通过sql查询信息
43 8
|
2月前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
72 4
|
2月前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。
|
2月前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
197 10
|
2月前
|
SQL 关系型数据库 MySQL
|
3月前
|
SQL 数据库 开发者
功能发布-自定义SQL查询
本期主要为大家介绍ClkLog九月上线的新功能-自定义SQL查询。
|
2月前
|
SQL 关系型数据库 MySQL
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
mysql编写sql脚本:要求表没有主键,但是想查询没有相同值的时候才进行插入
39 0
|
3月前
|
SQL 数据可视化 BI
SQL语句及查询结果解析:技巧与方法
在数据库管理和数据分析中,SQL语句扮演着至关重要的角色