草庐IT

关于sql server:如果另一个临时表没有返回行,则从一个临时表返回值

codeneng 2023-03-28 原文

Returning values from a temp table if another temp table returns no rows

如果另一个临时表没有返回行,我需要编写一个从一个临时表返回值的查询。

编辑:整个表具有以下结构

1
2
3
4
5
6
7
8
9
10
 NAME     TYPE  DATE      VALUE
Washington  1   NULL       1000  <--default value
Washington  2   NULL        750  <--default value
Washington  3   NULL        500  <--default value
Washington  1   04.11.2015  500
Washington  2   04.11.2015  250
Washington  3   04.11.2015  100
Washington  1   07.11.2015  600
Washington  2   07.11.2015  300
Washington  3   07.11.2015  200

临时表:Name, type, date, value 其中日期 IS NULL 返回"默认"值

临时表:Name, type, date, value,其中每个唯一的 Name 将有 3 种类型(1,2,3),每种类型都有不同的值,它们都具有相同的日期。

当日期列没有条目时,这意味着值应该是"默认",它们存储在同一个表中日期为空的行下

我也有 8 个不同的参数来确定值,但我只对 '1' 和 '2' 感兴趣,因此是 'case when'

所以我最后想要得到的是:

1
2
3
Select *
from temp1
where date =GETDATE()

如果它不存在,我希望它返回:

1
select * from temp2.

我只对今天、明天和后天的结果感兴趣

这是我到目前为止所得到的,但它显然不起作用。

如果能得到任何帮助,我将不胜感激

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
WITH    defaultvalues
          AS ( SELECT DISTINCT
                        n.Name ,
                        Type ,
                        Value
               FROM     mytable
                        LEFT JOIN nametable AS n ON mytable.x = r.Id
                                                    AND Date IS NULL
             ),
        changedvalue
          AS ( SELECT DISTINCT
                        n.Name ,
                        type ,
                        date ,
                        CASE WHEN d.Date = GETDATE()
                                  AND Parameter = '1' THEN Value
                             WHEN Parameter = '2' THEN '0'
                        END AS CAP
               FROM     mytable
                        LEFT JOIN nametable AS n ON mytable.x = r.Id
               WHERE    Parameter IN ( '1', '2' )
             )
    SELECT  CASE WHEN NOT EXISTS ( SELECT   *
                                   FROM     changedvalue
                                   WHERE    changedvalue.Date = GETDATE() )
                 THEN ( SELECT  *
                        FROM    defaultvalues
                      )
            END

  • 从故事中不清楚您到底想要什么,SQL 本身根本无法解释。请您创建并提供一些示例数据以及您期望的输出。如果需要,您可以使用 SqlFiddle 或 t-SQL flex 来提供数据。


您没有提供示例数据,只是基于您的 SQL 认为您只是在最后一部分遇到了问题:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
WITH  defaultvalues
        AS (
             SELECT DISTINCT
                    n.Name, [type], [date], [Value] AS cap
             FROM   mytable
             LEFT JOIN nametable AS n ON mytable.x = r.Id AND
                                         [Date] IS NULL
           ),
      changedvalue
        AS (
             SELECT DISTINCT
                    n.Name, [type], [date],
                    CASE WHEN d.Date = GETDATE() AND
                              Parameter = '1' THEN [Value]
                         WHEN Parameter = '2' THEN '0'
                    END AS CAP
             FROM   mytable
             LEFT JOIN nametable AS n ON mytable.x = r.Id
             WHERE  Parameter IN ( '1', '2' )
           )
  SELECT  *
  FROM    [changedvalue]
  UNION
  SELECT  *
  FROM    [defaultvalues]
  WHERE   NOT EXISTS ( SELECT *
                       FROM   [changedvalue] );

使用 Union 来组合两个答案

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
 WITH    defaultvalues
      AS ( SELECT DISTINCT
                    n.Name ,
                    Type ,
                    Value
           FROM     mytable
                    LEFT JOIN nametable AS n ON mytable.x = r.Id
                                                AND Date IS NULL
         ),
    changedvalue
      AS ( SELECT DISTINCT
                    n.Name ,
                    type ,
                    date ,
                    CASE WHEN d.Date = GETDATE()
                              AND Parameter = '1' THEN Value
                         WHEN Parameter = '2' THEN '0'
                    END AS CAP
           FROM     mytable
                    LEFT JOIN nametable AS n ON mytable.x = r.Id
           WHERE    Parameter IN ( '1', '2' )
         )
        (  SELECT   *
           FROM     changedvalue                                  
           WHERE    changedvalue.Date = GETDATE() )
          UNION
        ( SELECT    *
          FROM    defaultvalues
          WHERE NOT EXISTS (SELECT 1 FROM changedvalue ))
        END

这是一个例子:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
WITH    defaultvalues
          AS ( SELECT DISTINCT
                        n.Name ,
                        Type ,
                        Value
               FROM     mytable
                        LEFT JOIN nametable AS n ON mytable.x = r.Id
                                                    AND Date IS NULL
             ),
        changedvalue
          AS ( SELECT DISTINCT
                        n.Name ,
                        type ,
                        date ,
                        CASE WHEN d.Date = GETDATE()
                                  AND Parameter = '1' THEN Value
                             WHEN Parameter = '2' THEN '0'
                        END AS CAP
               FROM     mytable
                        LEFT JOIN nametable AS n ON mytable.x = r.Id
               WHERE    Parameter IN ( '1', '2' )
             ),
        final
          AS ( SELECT   * ,
                        RANK() OVER ( ORDER BY c ) r
               FROM     ( SELECT    * ,
                                    1 AS c
                          FROM      changedvalue
                          UNION ALL
                          SELECT    * ,
                                    2 AS c
                          FROM      defaultvalues
                        ) t
             )
    SELECT  *
    FROM    final
    WHERE   r = 1

您只需将结果与不同的 c 列合并。然后在列 c 上排名并选择排名等于 1 的位置。


如果没有样本数据,很难阅读和完全理解您的问题,但您似乎希望根据条件从两个表之一返回值。

看到两个临时表的架构相同,实现此目的的一种方法是简单地 UNION 将结果与 WHERE 子句中的条件检查一起。

我尝试创建一个简化的示例来展示如何执行此操作,如果您将以下代码复制并粘贴到 Management Studio 中,则该代码可以运行。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
CREATE TABLE #temp1 (Name VARCHAR(10), [type] VARCHAR(10), [date] DATE, value int)
CREATE TABLE #temp2 (Name VARCHAR(10), [type] VARCHAR(10), [date] DATE, value int)

INSERT INTO #temp1 ( Name, type, date, value )
VALUES  ( 'bob', 'male', '2015-03-12', 123)


INSERT INTO #temp2 ( Name, type, date, value )
VALUES  ( 'jane', 'female', GETDATE(), 456)

DECLARE @switch BIT = 1
-- with @switch set to 1, #temp1 will be returned
SELECT  t1.*
FROM    ( SELECT * FROM #temp1
          WHERE @switch = 1
          UNION
          SELECT * FROM #temp2
          WHERE @switch = 0
        ) t1

SET @switch = 0
--with @switch set to 0, #temp2 will be returned
SELECT  t1.*
FROM    ( SELECT * FROM #temp1
          WHERE @switch = 1
          UNION
          SELECT * FROM #temp2
          WHERE @switch = 0
        ) t1

DROP TABLE #temp1
DROP TABLE #temp2

我在 WHERE 条件上使用 @switch 的值来确定在 UNION 中调用哪个表。

有关关于sql server:如果另一个临时表没有返回行,则从一个临时表返回值的更多相关文章

  1. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  2. ruby-on-rails - Rails - 一个 View 中的多个模型 - 2

    我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何

  3. ruby-on-rails - 渲染另一个 Controller 的 View - 2

    我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>

  4. ruby - 为什么 4.1%2 使用 Ruby 返回 0.0999999999999996?但是 4.2%2==0.2 - 2

    为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返

  5. ruby-on-rails - 如果为空或不验证数值,则使属性默认为 0 - 2

    我希望我的UserPrice模型的属性在它们为空或不验证数值时默认为0。这些属性是tax_rate、shipping_cost和price。classCreateUserPrices8,:scale=>2t.decimal:tax_rate,:precision=>8,:scale=>2t.decimal:shipping_cost,:precision=>8,:scale=>2endendend起初,我将所有3列的:default=>0放在表格中,但我不想要这样,因为它已经填充了字段,我想使用占位符。这是我的UserPrice模型:classUserPrice回答before_val

  6. ruby-on-rails - 如果 Object::try 被发送到一个 nil 对象,为什么它会起作用? - 2

    如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象

  7. ruby - 为什么 SecureRandom.uuid 创建一个唯一的字符串? - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?

  8. ruby - 如果指定键的值在数组中相同,如何合并哈希 - 2

    我有一个这样的哈希数组:[{:foo=>2,:date=>Sat,01Sep2014},{:foo2=>2,:date=>Sat,02Sep2014},{:foo3=>3,:date=>Sat,01Sep2014},{:foo4=>4,:date=>Sat,03Sep2014},{:foo5=>5,:date=>Sat,02Sep2014}]如果:date相同,我想合并哈希值。我对上面数组的期望是:[{:foo=>2,:foo3=>3,:date=>Sat,01Sep2014},{:foo2=>2,:foo5=>5:date=>Sat,02Sep2014},{:foo4=>4,:dat

  9. ruby - 检查字符串是否包含散列中的任何键并返回它包含的键的值 - 2

    我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案

  10. ruby-on-rails - Rails - 从另一个模型中创建一个模型的实例 - 2

    我有一个正在构建的应用程序,我需要一个模型来创建另一个模型的实例。我希望每辆车都有4个轮胎。汽车模型classCar轮胎模型classTire但是,在make_tires内部有一个错误,如果我为Tire尝试它,则没有用于创建或新建的activerecord方法。当我检查轮胎时,它没有这些方法。我该如何补救?错误是这样的:未定义的方法'create'forActiveRecord::AttributeMethods::Serialization::Tire::Module我测试了两个环境:测试和开发,它们都因相同的错误而失败。 最佳答案

随机推荐