SQL SSMS CREATE TABLE 使用来自另一列的值

Posted

技术标签:

【中文标题】SQL SSMS CREATE TABLE 使用来自另一列的值【英文标题】:SQL SSMS CREATE TABLE use value from another column 【发布时间】:2021-12-22 03:42:50 【问题描述】:

我有一个练习,可以在一个代码中创建 2 个表。我正在创建两个表,现在我需要使用第二个表中第一个表的值。这是它的样子:

CREATE TABLE a(
[hours]int NOT NULL,
)

CREATE TABLE b(
[example] varchar(60) NOT NULL PRIMARY KEY,
[simple_name] AS (CASE WHEN example = 'name' THEN 40 
                       WHEN example = 'name2' THEN 45 END) /*THIS IS WHAT I WANT TO DO: * [a](hours)  */,
)

如何在第二个表中使用第一个表的小时数?我想要的是从第一个表乘以 40 或 45 小时。

【问题讨论】:

使用CROSS JOIN? 【参考方案1】:

我认为观点可能是您的答案:

CREATE TABLE a ([hours]int NOT NULL);

CREATE TABLE b ([example] varchar(60) NOT NULL PRIMARY KEY)
GO

CREATE VIEW v as 
    SELECT
        [example],
        [simple_name] = CASE 
                            WHEN example = 'name'  THEN 40 
                            WHEN example = 'name2' THEN 45 
                        END
                        * a.hours
 
    FROM b
    CROSS JOIN a -- this is a cross join and perhaps it has to be replaced with some other types of join: inner, left, right, full?

然后将视图用作常规表格:

select * from v

【讨论】:

以上是关于SQL SSMS CREATE TABLE 使用来自另一列的值的主要内容,如果未能解决你的问题,请参考以下文章

SSMS - Sql,从表中选择数据以创建数据透视结果

sql server 行转列

sql create_table.sql

HiveQL/SQL:CREATE TABLE AS SELECT (CTAS) 和 CREATE EXTERNAL TABLE + INSERT INTO 有啥区别?

SQL Server 中“CREATE TABLE table AS”中的“分发选项”错误

SQL篇章--CREATE TABLE