在select子句里如何实现另一个select语句的查询|在select子句里用逗号隔开的每个项的本质是一个表达式

本文详细介绍了如何在SQL的SELECT语句中使用CASE语句结合子查询来实现复杂的数据转换。通过示例展示了在CASE中嵌套单行SELECT子查询,并解释了当子查询返回多行时的错误情况。同时,讨论了在SELECT列表中使用表达式的限制和规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在select子句里能支持另一个select语句的实现形式如下(即要配合case when关键字):

select

case when lock_purpost in(SELECT id from data_dictionary) then (SELECT name from data_dictionary where id=lock_purpost)  else lock_purpost end as lock_purpost(别名),

case when lock_framework in(SELECT id from data_dictionary) then (SELECT name from data_dictionary where id=lock_framework) else lock_framework end as lock_framework

from v_photosum_attach ;

注释:
1、这个语句看出,我们可以在表v_photosum_attach上的一行数据行上对两个不同列lock_purpost和lock_framework各自进行一次独立的查询(另一个表,即when部分)和处理(then部分),即相当于可以在v_photosum_attach上的同一行数据行上进行了多次查询处理。
2、

select

case when lock_purpost in(SELECT id from data_dictionary) then (SELECT name from data_dictionary where id=lock_purpost)  else null(即若不符合when里的条件则该行上的列lock_purpost的列值置为null) end as lock_purpost(别名)

from v_photosum_attach ;

参考:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值