SQL求助 我有2条记录,有一个字段的值不一样 我现在想查询的时候

传入的参数如果能查到这条记录就返回这条记录查不到就返回另一条记录这个语句该怎么写... 传入的参数如果能查到这条记录就返回这条记录
查不到就返回另一条记录
这个语句该怎么写
展开
 我来答
micro0369
2012-07-06 · TA获得超过1.2万个赞
知道大有可为答主
回答量:9250
采纳率:85%
帮助的人:4243万
展开全部
用case when 大致如下
select case when count(*)=0 then (select col from tab where colid=otherid) else col end col from tab where colid=paraid
只能取一列,取多列需要多个case when
paraid为你的参数,otherid为另一行的标识

其实这个用存储过程就简单了,if else 既可
苏州蓝晓生物科技有限公司_
2022-08-05 广告
苏州蓝晓生物科技有限公司。标准化核心产品:公司拥有完整的琼脂糖介质、葡聚糖介质、聚甲基丙烯酸酯介质生产线,年产分离介质50000L,产品质量稳定并达到国际领先水平。核心优势:公司核心技术人员拥有近二十年不同基质的基球开发和官能化的丰富技术经... 点击进入详情页
本回答由苏州蓝晓生物科技有限公司_提供
百度网友3a8f439
2012-07-09 · TA获得超过300个赞
知道小有建树答主
回答量:224
采纳率:100%
帮助的人:163万
展开全部
这个判断用一个存储过程做比较方便;
定义一个变量,将传入的值代入查询的记录数插入这个变量中,如:
select count(1) into v_count from table where table.id = iv_inid;
if v_count = 0 then
select * from table where table.id <> iv_inid;
else
select * from table where table.id = iv_inid;

end if;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
弭景龙05Z
2021-05-14
知道答主
回答量:1
采纳率:0%
帮助的人:516
展开全部
select case when a=a then a
when a <> a then '' end from table
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式