Sql case when then else end

中国好梦 2017-12-11 07:51:21

下列的sql in 与case when then else end 使用 当t.flag不等于1时查不到数据 应该如何使用呢???
select * from tab1 t where t.colum1 in(case t.flag when 1 then '003' else '''001''' + ','+ '''002''' end)
...全文
399 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
吉普赛的歌 2017-12-12
  • 打赏
  • 举报
回复
SELECT * FROM tab1 t
WHERE t.flag=1 AND t.colum1='003'
UNION ALL
SELECT * FROM tab1 t
WHERE t.flag!=1 AND t.colum1 IN('001','002')
二月十六 2017-12-11
  • 打赏
  • 举报
回复
试试这样
SELECT  *
FROM    tab1 t
WHERE   ( CASE WHEN t.flag = 1 THEN CHARINDEX(t.colum1, '003')
               ELSE CHARINDEX(t.colum1, '001,002')
          END ) > 0; 

590

社区成员

发帖
与我相关
我的任务
社区描述
提出问题
其他 技术论坛(原bbs)
社区管理员
  • community_281
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧