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 使用来自另一列的值的主要内容,如果未能解决你的问题,请参考以下文章
HiveQL/SQL:CREATE TABLE AS SELECT (CTAS) 和 CREATE EXTERNAL TABLE + INSERT INTO 有啥区别?