为了说明如何使用计算字段,本文将通过一个简单的示例来展示如何将两列组合成一个标题。假设Vendors
表包含供应商的名称和国家信息,我们希望生成一个报表,其中列出每个供应商的名称和所在国家,并且需要格式化名称显示,国家名用括号括起来。这些信息并未单独存储在数据库中,而是存储在vend_name
和vend_country
两列中。我们如何在SQL查询中生成这个组合值呢?
拼接字段的方法
解决方案是将这两列数据拼接成一个新字段。在SQL中,可以使用特定的操作符来实现列拼接。不同的数据库管理系统(DBMS)使用不同的拼接符号。常见的操作符有:
- SQL Server : 使用加号(
+
)进行拼接 - Access : 使用和符号(
&
)拼接 - DB2、Oracle、PostgreSQL、SQLite : 使用竖杠(
||
)拼接 - MySQL、MariaDB : 使用
CONCAT
函数进行拼接
示例:SQL Server
在SQL Server中,我们可以使用加号(+
)将两列拼接:
sql
SELECT vend_name + ' (' + vend_country + ')'
FROM Vendors
ORDER BY vend_name;
输出结果如下:
示例:其他数据库
对于其他数据库,如Oracle、PostgreSQL等,拼接符号使用||
:
sql
SELECT vend_name || ' (' || vend_country || ')'
FROM Vendors
ORDER BY vend_name;
示例:Access
在Access中,拼接操作使用&
符号:
sql
SELECT vend_name & '(' & vend_country & ')'
FROM Vendors
ORDER BY vend_name;
示例:MySQL和MariaDB
在MySQL或MariaDB中,拼接则使用CONCAT
函数:
sql
SELECT CONCAT(vend_name, ' (', vend_country, ')')
FROM Vendors
ORDER BY vend_name;
拼接字段的元素
以上SELECT语句将以下四个元素拼接在一起:
- 存储在
vend_name
列中的供应商名称 - 包含一个空格和左括号的字符串
- 存储在
vend_country
列中的国家名称 - 包含右括号的字符串
结果是一个新的计算字段,它将这四个元素组合为一个单一的列。
再看看上述 SELECT 语句返回的输出。结合成一个计算字段的两个列用
空格填充。许多数据库(不是所有)保存填充为列宽的文本值,而实际
上你要的结果不需要这些空格。为正确返回格式化的数据,必须去掉这些空格。
这可以使用SQL的RTRIM()函数来完成,如下所示:
sql
SELECT RTRIM(vend_name) + ' (' + RTRIM(vend_country) + ')' FROM Vendors
ORDER BY vend_name;
输出如下:
大部分DBMS都支持RTRIM()
(去除字符串右侧空格)、LTRIM()
(去除左侧空格)以及TRIM()
(去除两端空格)。
使用列别名
在前面的查询中,拼接的结果是一个计算字段,但这个字段没有名称。如果仅在SQL查询工具中查看,可能没有问题,但在客户端应用中,未命名的字段无法引用。因此,SQL允许我们为计算字段指定别名。
使用AS
关键字可以为计算字段指定一个名称。例如,我们可以将拼接后的结果命名为vend_title
:
sql
SELECT RTRIM(vend_name) + ' (' + RTRIM(vend_country) + ')' AS vend_title
FROM Vendors
ORDER BY vend_name;
输出如下:
对于其他DBMS,语法如下:
-
Oracle/PostgreSQL/SQLite :
sqlSELECT RTRIM(vend_name) || ' (' || RTRIM(vend_country) || ')' AS vend_title FROM Vendors ORDER BY vend_name;
-
Access (使用
Trim
函数去除两端空格):sqlSELECT Trim(vend_name) & ' (' & Trim(vend_country) & ')' AS vend_title FROM Vendors ORDER BY vend_name;
-
MySQL/MariaDB:
sql
SELECT CONCAT(RTrim(vend_name), ' (', RTrim(vend_country), ')') AS vend_title
FROM Vendors
ORDER BY vend_name;
总结
通过以上示例,我们展示了如何在SQL中拼接字段,并确保格式正确。通过使用适当的拼接符号和去除空格的函数,我们能够精确地生成所需的格式化数据。此外,列别名使得计算字段更具可读性和可引用性,尤其在客户端应用中非常有用。