首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >条件选择中的重复连接

条件选择中的重复连接
EN

Stack Overflow用户
提问于 2013-09-15 14:10:59
回答 1查看 89关注 0票数 1

客户端的标签由以下内容组成:

  • 他的头衔(小姐/先生/夫人/女士),
  • 他的名字,
  • 他的姓。

其最大大小必须为20个字符:

  • 如果标签大小> 20,则将名称缩为带有圆点的首字母(Nancy变为N),
  • 如果标签大小仍然大于20,则整个标签被截断为20个字符。

我所做的是:

代码语言:javascript
复制
SELECT
    UPPER(
        CASE WHEN 
            LENGTH(CONCAT(clientTitle, " ", clientFirstname, " ", clientSurname)) > 20
        THEN 
            CONCAT(clientTitle, " ", CONCAT(SUBSTR(clientFirstname, 1, 1), "."), " ", clientSurname)
        ELSE 
            CONCAT(clientTitle, " ", clientFirstname, " ", clientSurname)
        END
    ) AS label
FROM Client

很管用,但对我来说不太好。级联陈述书写了3次,在任何情况下都写了2次。你知道我怎样才能使这个查询更好,更有表现力吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-09-15 14:16:31

您可以将case移动到concat()中,只需使用名称即可。

代码语言:javascript
复制
SELECT upper(concat(c.clientTitle, ' ',
                    (case when length(concat(c.clientTitle, ' ', c.clientFirstname, ' ', c.clientSurname)) > 20
                          then concat(left(c.clientFirstName, 1), '.')
                          else c.clientFirstName
                     end), ' ',
                    c.clientSurname
                   )
            ) AS label
FROM Client c;

我还通过删除两个空格并将20更改为20 - 2来更改长度计算(公式的意思是提醒您缺少两个空格)。使用表别名还可以提高代码的可读性。

而且,我不担心一种方法和另一种方法的性能。短字符串上的操作通常不是性能的驱动程序。

编辑:

如果您的关注点是具体的连接,那么对length执行多个调用:

代码语言:javascript
复制
SELECT upper(concat(c.clientTitle, ' ',
                    (case when length(c.clientTitle) + length(c.clientFirstname) + length(c.client_Surname) > 20 - 2
                          then concat(left(c.clientFirstName, 1), '.')
                          else c.clientFirstName
                     end), ' ',
                    c.clientSurname
                   )
            ) AS label
FROM Client c;

然而,这种微优化不太可能对您的应用程序产生任何影响。

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

https://stackoverflow.com/questions/18813326

复制
相关文章

相似问题

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