首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >SQL -在哪里可以使用别名吗?

SQL -在哪里可以使用别名吗?
EN

Stack Overflow用户
提问于 2017-05-04 18:37:02
回答 4查看 4.5K关注 0票数 4

我在示例游乐场页面上尝试了W3Schools中的以下SQL。

代码语言:javascript
运行
复制
SELECT CustomerID AS Id, CustomerName AS Customer
FROM Customers
WHERE Customer="Alfreds Futterkiste";

但我得到了No value given for one or more required parameters.作为回应。如果我使用CustomerName而不是别名,它就能工作。

这是操场测试页面的失败,还是根本不可能?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2017-05-04 18:44:02

WHERE子句在select之前进行计算。因此where子句不知道您使用的别名。

因此,您需要使用原始列名:

代码语言:javascript
运行
复制
SELECT CustomerID AS Id, CustomerName AS Customer
FROM Customers
WHERE CustomerName="Alfreds Futterkiste";

如果必须在where子句中使用别名,则可以使用子查询或CTE (过高,可能导致查询速度较慢):

代码语言:javascript
运行
复制
SELECT * from (
    SELECT CustomerID AS Id, CustomerName AS Customer
    FROM Customers
) t WHERE Customer = "Alfreds Futterkiste";
票数 3
EN

Stack Overflow用户

发布于 2017-05-04 18:39:44

查看您的代码:

代码语言:javascript
运行
复制
SELECT CustomerID AS Id, CustomerName AS Customer
FROM Customers
WHERE Customer="Alfreds Futterkiste";

要对customer表进行别名,可以执行以下操作:

代码语言:javascript
运行
复制
SELECT c.CustomerID AS Id, c.CustomerName AS Customer
    FROM Customers c
    WHERE c.CustomerName="Alfreds Futterkiste";

其中c现在是客户的别名。

不可能在where子句中使用列别名,因为where子句在select之前执行。

票数 3
EN

Stack Overflow用户

发布于 2017-05-04 18:43:09

丑陋,但在更大、更复杂的查询中更方便。

代码语言:javascript
运行
复制
SELECT * FROM
(SELECT CustomerID AS ID, CustomerName AS Customer
FROM Customers) as A

WHERE Customer = "Alfreds Futterkiste";
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43790424

复制
相关文章

相似问题

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