首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL根据查询结果返回自定义值,同时考虑到性能

SQL根据查询结果返回自定义值,同时考虑到性能
EN

Stack Overflow用户
提问于 2013-01-29 00:45:27
回答 1查看 443关注 0票数 0

我需要关于查询性能的帮助,我有一个非常慢的查询。

该查询在列上执行case,以便根据数字返回不同的文本值。如果我有一个值为1-5和8-10的表格,如果某个东西的值为1,它应该显示'Apple‘,如果它是2,它必须显示'pear’,如果它不是1-5,那么它就是' other‘。目前使用的是case语句,但我听说查询上的函数会使速度变慢。

我想要的只是“措辞”而不是数字,但因为表格太大了,我感觉它只是在迭代每一行,以确定要显示的内容。

有没有更快的方法呢?我考虑过做一个连接,这看起来会很好用,但我不知道如何写除1-5以外的其他东西

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-01-29 00:54:32

case语句不是函数。在某些版本的SQL中,用户定义函数确实有额外的开销。一般来说,您不需要担心内置函数的开销。

您可以使用如下连接来完成此操作:

代码语言:javascript
复制
with lookup  as (
     select 1 as val, 'Apple' as str union all
     select 2 as val, 'Pear' as str union all
     select 3 union all select 4 union all select 5
)
select coalesce(l.val, 'other')
from t left outer join
     lookup l
     on t.col = l.val

不过,我预计case语句会稍微快一点。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14566865

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档