case 嵌套查询与连接查询你需要懂得

Case 子查询连接查询在sql开发中很常用的一个查询功能,感兴趣的你可不要错过本文,接下来为你详细介绍下

代码如下:
select * from score
create database demo
use demo
create table [user]
(
[uId] int identity( 1 ,1 ) primary key,
[name] varchar ( 50),
[level] int –1骨灰大虾菜鸟
)
insert into [user] ( name, level ) values (‘ 犀利哥 ‘, 1 )
insert into [user] ( name, level ) values (‘ 小月月 ‘, 2 )
insert into [user] ( name, level ) values (‘ 芙蓉姐姐 ‘, 3 )
–case end 单值判断 相当于 switch case
–then 后面的返回值类型必须一致
select [name] ,
case [level]
when 1 then ‘骨灰 ‘
when 2 then ‘大虾 ‘
when 3 then ‘菜鸟 ‘
end as ‘等级 ‘
from [user]
use MySchool
select * from score
–case end 第二种用法,相当于多重 if 语句
select studentId ,
case
when english >=90 then ‘ 优 ‘
when english >=80 and english when english >=70 and english when english >= 60 and english else ‘ 差 ‘
end as ‘成绩 ‘
from score
order by english

— 表中有A B C 三列 ,用 SQL 语句实现:当 A列大于 B 列时选择A 列否则选择 B 列,当B 列大于 C列时选择 B 列否则选择 C列。
select
case
when a > b then a
else b
end ,
case
when b > c then b
else c
end
from T

— 练习
create table test
(
number varchar ( 10),
amount int
)
insert into test( number ,amount ) values ( ‘RK1’, 10 )
insert into test( number ,amount ) values ( ‘RK2’, 20 )
insert into test( number ,amount ) values ( ‘RK3’,- 30 )
insert into test( number ,amount ) values ( ‘RK4’,- 10 )
select number ,
case
when amount > 0 then amount
else 0
end as ‘收入 ‘ ,
case
when amount else 0
end as ‘支出 ‘
from test
–结果如下

代码如下:
— 有一张表student0 ,记录学生成绩
use demo
CREATE TABLE student0 ( name nvarchar (10 ), subject nvarchar (10 ), result int )
INSERT INTO student0 VALUES (‘ 张三 ‘, ‘ 语文’ , 80)
INSERT INTO student0 VALUES (‘ 张三 ‘, ‘ 数学’ , 90)
INSERT INTO student0 VALUES (‘ 张三 ‘, ‘ 物理’ , 85)
INSERT INTO student0 VALUES (‘ 李四 ‘, ‘ 语文’ , 85)
INSERT INTO student0 VALUES (‘ 李四 ‘, ‘ 数学’ , 92)
INSERT INTO student0 VALUES (‘ 李四 ‘, ‘ 物理’ ,null)
select * from student0
select [name] ,
isnull (sum ( case subject
when ‘ 语文 ‘ then result
end ),0 ) as ‘语文 ‘ ,
isnull (sum ( case subject
when ‘ 数学 ‘ then result
end ),0 ) as ‘数学 ‘ ,
isnull (sum ( case subject
when ‘ 物理 ‘ then result
end ),0 ) as ‘物理 ‘
from student0
group by [name]

代码如下:
— 子查询将一个查询语句做为一个结果集供其他 SQL 语句使用,就像使用普通的表一样,
— 被当作结果集的查询语句被称为子查询。所有可以使用表的地方几乎都可以使用子查询来代替。
use myschool
select sName from ( select * from student ) as t
select 1,( select sum ( english) from score ) as ‘ 和 ‘,( select avg ( sAge) from student ) as ‘ 平均年龄 ‘
— 查询高一一班所有的学生
select * from student where sClassId =
( select cId from class where cName = ‘高一一班 ‘ )
— 查询高一一班 高二一班所有的学生
— 子查询返回的值不止一个。当子查询跟随在 = 、!= 、 、 >= 之后
— 子查询跟在比较运算符之后,要求子查询只返回一个值
— 如果子查询是多行单列的子查询,这样的子查询的结果集其实是一个集合。可以使用 in 关键字代替 =号
select * from student where sClassId =
( select cId from class where cName in ( ‘高一一班 ‘ ,’ 高二一班 ‘))
select * from student where sClassId in
( select cId from class where cName in ( ‘高一一班 ‘ ,’ 高二一班 ‘))
— 查询刘关张的成绩
select * from score where studentId in
( select sId from student where sName in ( ‘刘备 ‘ ,’ 关羽 ‘, ‘ 张飞’ ))
— 删除刘关张
delete from score where studentId in
( select sId from student where sName in ( ‘刘备 ‘ ,’ 关羽 ‘, ‘ 张飞’ ))

— 实现分页
— 最近入学的个学生
select top 3 * from student
order by sId desc
— 查询第到个学生
select top 3 * from student
where sId not in ( select top 3 sId from student order by sId desc)
order by sId desc
— 查询到的学生
select top 3 * from student
where sId not in ( select top 6 sId from student order by sId desc)
order by sId desc
— 上面是sql 2000 以前的实现方式。 SQLServer2005 后增加了Row_Number 函数简化实现。
–sql 2005 中的分页
select * from
( select row_number () over (order by sId desc ) as num,* from student ) as t
where num between 1 and 3
select * from
( select row_number () over (order by sId desc ) as num,* from student ) as t
where num between 4 and 6
select * from
( select row_number () over (order by sId desc ) as num,* from student ) as t
where num between 7 and 9
select * from
( select row_number () over (order by sId desc ) as num,* from student ) as t
where num between 3 *( 3- 1 ) + 1 and 3 *3
— 表连接
— 交叉连接cross join
select * from student
cross join class
— 内连接inner join…on…
select * from student
inner join class on sClassId = cId
select * from class
— 查询所有学生的姓名、年龄及所在班级
select sName , sAge, cName ,sSex from student
inner join class on sClassId = cId
where sSex =’ 女 ‘
— 查询年龄超过岁的学生的姓名、年龄及所在班级
select sName , sAge, cName from class
inner join student on sClassId = cId
where sAge > 20
— 外连接
–left join…on…
select sName , sAge, cName from class

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1802193.html

(0)
上一篇 2025年2月21日 13:17:41
下一篇 2025年2月21日 13:17:58

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 如何使用PHP在MongoDB中进行嵌套查询

    如何使用php在mongodb中进行嵌套查询 摘要:本文将介绍如何使用PHP语言在MongoDB数据库中进行嵌套查询。通过示例代码演示,读者将学习到如何使用PHP MongoDB驱动程序来执行嵌套查询。 引言 在开发Web应用程序时,数据库…

    编程技术 2025年2月23日
    200
  • MySQL 连接查询超级详解

                                                            1 作用 在数据库中join操作被称为连接,作用是能连接多个表的数据(通过连接条件),从多个表中获取数据合并在一起作为结果集返回…

    2025年2月19日
    200
  • MySQL数据查询之连接查询

    连接关系是关系数据库模型的主要特点。也是最主要的查询,主要包括内连接、外连接等。通过连接运算符可以实现多个表查询。在关系数据库管理系统中,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在一个表中。当查询数据时,通过连接操作查询…

    2025年2月19日
    300
  • 如何使用MySQL的嵌套查询实现复杂的数据分析

    如何使用mysql的嵌套查询实现复杂的数据分析 在现代数据驱动的世界中,数据分析已经成为了各行各业中不可或缺的一部分。而对于数据库领域而言,MySQL作为一种常见的关系型数据库管理系统,其嵌套查询功能能够极大地提升数据分析的灵活性和效率。本…

    数据库 2025年2月18日
    300

发表回复

登录后才能评论