首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >选择名称where案例值>另一个案例值+2

选择名称where案例值>另一个案例值+2
EN

Stack Overflow用户
提问于 2019-10-25 03:03:22
回答 1查看 18关注 0票数 0

在这个查询的最后部分遇到了一些问题。

我要找的是capvalue < desiredCapValue + 2。

这意味着如果capValue = 1,我将查找desiredCapValue等于或大于3的任何值。

代码语言:javascript
复制
SELECT instanceName, capacitySizeName, desiredCapacitySizeName, desiredCapValue, capvalue FROM
(SELECT instance_name AS instanceName, capacity_size_name AS capacitySizeName, 
(CASE capacity_size_name WHEN 'small' THEN '1' WHEN 'medium' THEN '2' WHEN 'large' THEN '3' WHEN 'xlarge' THEN '4' WHEN 'xxlarge' THEN '5' WHEN 'mega' THEN '6' WHEN 'ultra' THEN '7' WHEN 'giga' THEN '8' WHEN 'tera' THEN '9' WHEN 'peta' THEN '10' END) AS `capValue`, 
u_desired_capacity_size_name AS desiredCapacitySizeName, 
CASE u_desired_capacity_size_name WHEN 'small' THEN '1' WHEN 'medium' THEN '2' WHEN 'large' THEN '3' WHEN 'xlarge' THEN '4' WHEN 'xxlarge' THEN '5' WHEN 'mega' THEN '6' WHEN 'ultra' THEN '7' WHEN 'giga' THEN '8' WHEN 'tera' THEN '9' WHEN 'peta' THEN '10' END AS `desiredCapValue` 
FROM mysql_view 
WHERE used_for = 'Production')A 
WHERE capvalue < desiredCapValue+2 LIMIT 10

提前感谢!

EN

回答 1

Stack Overflow用户

发布于 2019-10-25 03:21:10

您需要数字(而不是字符串)才能进行有效的算术求值和右大写< desiredCapValue+2比较

代码语言:javascript
复制
  SELECT instanceName
    , capacitySizeName
    , desiredCapacitySizeName
    , desiredCapValue
    , capvalue 
  FROM ( 
      SELECT instance_name AS instanceName
      , capacity_size_name AS capacitySizeName
      ,  (CASE capacity_size_name 
            WHEN 'small' THEN 1 
            WHEN 'medium' THEN 2 
            WHEN 'large' THEN 3 
            WHEN 'xlarge' THEN 4
            WHEN 'xxlarge' THEN 5 
            WHEN 'mega' THEN 6 
            WHEN 'ultra' THEN 7 
            WHEN 'giga' THEN 8 
            WHEN 'tera' THEN 9 
            WHEN 'peta' THEN 10 END) AS `capValue`
      , u_desired_capacity_size_name AS desiredCapacitySizeName
      , CASE u_desired_capacity_size_name 
            WHEN 'small' THEN 1 
            WHEN 'medium' THEN 2 
            WHEN 'large' THEN 3 
            WHEN 'xlarge' THEN 4 
            WHEN 'xxlarge' THEN 5 
            WHEN 'mega' THEN 6 
            WHEN 'ultra' THEN 7
            WHEN 'giga' THEN 8 
            WHEN 'tera' THEN 9 
            WHEN 'peta' THEN 10 END AS `desiredCapValue` 
  FROM mysql_view 
  WHERE used_for = 'Production'
  ) A 
  WHERE capvalue < desiredCapValue+2 
  LIMIT 10
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58547687

复制
相关文章

相似问题

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