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

news2024/9/21 22:14:56

文章目录

    • SQL学前导图
    • 一 、基本信息
      • 1 相关名词
        • 数据库相关基本概念:字段、属性、记录(元祖)、表、主键、外键
      • 2 基本语句
      • 3 约束:主键约束、外键约束、check约束、default约束、唯一约束
    • 二、查询
      • 1 计算列
      • 2 distinct(去重)
      • 3 between
      • 4 in包含
      • 5 top 分页【取前几个值】
      • 6 null
      • 7 order by 排序
        • 排序:order by 排序【默认升序】
      • 8 模糊查询
        • 转义字符 【escape ‘\’】
    • 三、聚合函数
    • 四、分组 group by
      • having对分组后的数据进行过滤
    • 五、链接查询(多表查询)
      • 内链接:
        • (1)select ... from A,B
        • (2)select ... from A,B where ...
        • (3)select ... from A join B on ...
        • (4)select ... from A,B
      • 外链接
      • 自连接
      • 联合的用法【union】
    • 六 分页查询【top只有SqlServer有】
        • 公式:
      • identity关键字:主键自动增长;【当被删除一个数据后:会打断主键连续自增】
    • 七 视图:

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

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

SQL学前导图


:::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 '\'

三、聚合函数

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

  • 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

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


内链接:

(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)左外链接

  1. 用左表的第一行分别和右表的所有行进行联接,如果有匹配的行,则一起输出,如果右表有多行匹配,则结果集输出多行,如果没有匹配行,则结果集中只输出一行,该输出行左边为左表第一行内容,右边全部输出null
  2. 然后再用左表第二行和右边所有行进行联接,如果有匹配的行,则一起输出,如果右表有多行匹配,则结果集输出多行,如果没有匹配行,则结果集中只输出一行,该输出行左边为左表第二行内容,右边全部输出null
  3. 以此类推,直至左边所有行连接完毕
  4. 因为右边很可能出现有多行和左边的某一行匹配,所以左联接产生的结果集的行数很可能大于leftjoin 左边表的记录的总数
  5. 左向外联接的结果集包括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

学习思维:
在这里插入图片描述

七 视图:

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

 -- 视图操作
 --创建vs1视图
 CREATE VIEW vs1
  AS SELECT ename,deptno FROM emp

 -- 使用视图vs1查数据
  select sal from vs1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/69584.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

生产跟踪是生产控制的基础,其主要功能有哪些?

生产跟踪是生产控制的基础&#xff0c;只有对生产的过程全面了解&#xff0c;才能掌握和控制生产的执行情况&#xff0c;所以生产跟踪模块在制造执行系统中一种起着举足轻重的作用。生产跟踪&#xff0c;不单单是对生产过程进行监控和记录数据&#xff0c;还需要将各个生产环节…

2023最新SSM计算机毕业设计选题大全(附源码+LW)之java校园新闻发布管理系统574ec

面对老师五花八门的设计要求&#xff0c;首先自己要明确好自己的题目方向&#xff0c;并且与老师多多沟通&#xff0c;用什么编程语言&#xff0c;使用到什么数据库&#xff0c;确定好了&#xff0c;在开始着手毕业设计。 1&#xff1a;选择课题的第一选择就是尽量选择指导老师…

ubuntu18.04上点云PCL 库使用初探

PCL 库使用资料 在 ubuntu18.04 上使用pcl记录 一、 安装 首先需要在 ubuntu 上安装c 库 sudo apt install libpcl-dev dpkg -S pcl 查看包文件安装的位置&#xff0c;包括头文件和库文件&#xff0c;进到库文件路径下看&#xff0c;目前安装的是 pcl 1.8.1 /usr/include/pc…

最全Java知识点总结归纳

一、流 Java所有的流类位于http://java.io包中&#xff0c;都分别继承字以下四种抽象流类型。 继承自InputStream/OutputStream的流都是用于向程序中输入/输出数据&#xff0c;且数据的单位都是字节(byte8bit)。 继承自Reader/Writer的流都是用于向程序中输入/输出数据&#x…

黄佳《零基础学机器学习》chap3笔记

黄佳 《零基础学机器学习》 chap3笔记 第3课 线性回归——预测网店的销售额 文章目录黄佳 《零基础学机器学习》 chap3笔记第3课 线性回归——预测网店的销售额3.1 问题定义&#xff1a;小冰的网店广告该如何投放3.2 数据的收集和预处理3.2.1 收集网店销售额数据3.2.2 数据读取…

功能测试(五)—— web项目抓包操作与测试报告

目录 目标 一、网络相关知识介绍 1.1 请求 1.2 响应 二、抓包工具的应用 2.1 过滤 2.2 删除数据 2.3 查看数据包内容 2.4 定位Bug 2.5 弱网测试 2.6 设置断点&#xff08;请求之前&#xff09; 2.7 设置断点&#xff08;响应之后&#xff09; 三、测试报告 目标 …

Java 多线程ThreadLocal使用

前面文章多线程间的同步控制和通信&#xff0c;是为了保证多个线程对共享数据争用时的正确性的。那如果一个操作本身不涉及对共享数据的使用&#xff0c;相反&#xff0c;只是希望变量只能由创建它的线程使用&#xff08;即线程隔离&#xff09;就需要到线程本地存储了。 Java…

Spring学习:三、Spring IoC 容器配置-注解方式

5. Spring IoC 容器配置-注解方式 5.1 注解定义Bean对象 在Bean class 添加 注解 Spring2.5 提供 Component 效果相当于 <bean> 元素 配置包扫描&#xff0c;通知spring 注解Bean 在哪个包下面 使用 <context> 命名空间 ,在spring的配置文件中添加context命令空…

【图】认识与表达

文章目录一、图的基本构成二、图的表达方式1&#xff09;邻接矩阵2&#xff09;邻接表3&#xff09;数组4&#xff09;综合一、图的基本构成 地图上有很多的建筑&#xff0c;每个建筑之间有着四通八达的道路连接着&#xff0c;如果想要使用数据结构来表示建筑和建筑之间的道路…

知识图谱-KGE-语义匹配-双线性模型-2019:CrossE

【paper】 Interaction Embeddings for Prediction and Explanation in Knowledge Graphs【简介】 本文是浙大和苏黎世大学的学者联合发表于 WSDM 2019 上的工作&#xff0c;文章提出了 CrossE&#xff0c;模型的思想也没有很高端&#xff0c;就是引入了一个矩阵C&#xff0c;用…

List——顺序表链表OJ

文章目录前言一、合并两个有序链表二、使用顺序表实现“杨辉三角”三、环形链表四、环形链表Ⅱ总结前言 上两篇内容&#xff0c;对链表和顺序表进行了讲解并手动实现了自己的顺序表和链表&#xff0c;本篇文章将结合LeetCode上的OJ题&#xff0c;进行具体的使用以熟悉其中的方…

Spring注解式缓存redis

一、Spring 整合redis 导入依赖 <redis.version>2.9.0</redis.version> <redis.spring.version>1.7.1.RELEASE</redis.spring.version><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId>&l…

Qt中操作SQLite数据库

0.前言 SQLite是一款开源、轻量级、跨平台的数据库&#xff0c;无需server&#xff0c;无需安装和管理配置。它的设计目标是嵌入式的&#xff0c;所以很适合小型应用&#xff0c;也是Qt应用开发种常用的一种数据库。 1.驱动 Qt SQL模块使用驱动程序插件&#xff08;plugins&am…

多线程与高并发(一)

【前言】&#xff1a; 多线程、JVM、操作系统。 【概述】&#xff1a; 基础概念 JUC同步工具 同步容器 Disruptor //一个MQ框架&#xff0c;公认的单机环境下效率最高。 线程池 【线程的概念】&#xff1a; 【纤程】&#xff1a; 【 run和start的区别 】&#xff1a; //n…

[附源码]Python计算机毕业设计SSM家用饰品在线销售系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

【面试问题】进程和线程的区别——通俗易懂

1. ”进程“是什么1.2 管理进程1.3 内存管理1.4 进程间通信2. 线程是什么3.进程和线程的区别1. ”进程“是什么 在对比"进程"和"线程"两者之间的区别前,我们需要先了解什么是"进程"?什么是"线程"? **“进程”(process)也叫"任…

HIFI测序揭示拟南芥MSH1参与介导的细胞器基因组重组与变异积累规律

近日&#xff0c;中国农业科学院农业基因组所武志强课题组在《The Plant Journal》在线发表了题为“Long-read sequencing characterizes mitochondrial and plastid genome variants in Arabidopsis msh1 mutants”的研究论文&#xff0c;该研究通过高精度的长读长测序&#x…

安卓APP源码和设计报告——仿淘宝水果商城

项目名称 仿淘宝水果商城项目概述 随着互联网技术地高速发展&#xff0c;计算机进入到每一个人的生活里&#xff0c;从人们的生活方式到整个社会的运转都产生了巨大的变革&#xff0c;而在信息技术发达的今天&#xff0c;互联网的各种娱乐方式都在渗透到人们的生活方式之中&…

Procreate绘画教程

Procreate绘画教程 从 30 多年的设计师/插画家那里彻底有效地学习 Procreate&#xff01;已更新至 Procreate 5.2&#xff01; 课程英文名&#xff1a;Procreate Solid Foundations 此视频教程共10.0小时&#xff0c;中英双语字幕&#xff0c;画质清晰无水印&#xff0c;源码…

三条建议!让您在世界杯期间确保网络安全!

2022年11月&#xff0c;全球的目光都聚焦在依旧“夏日炎炎”的卡塔尔。随着人们观看、分享赛事的习惯从传统的电视转为网络&#xff0c;世界杯必将成为整个2022年的“流量王”。在我国&#xff0c;仅仅德国与日本的一场比赛在微博平台就带来了13.8亿次阅读。 据估计&#xff0…