7-创建计算字段
7.1-计算字段
存储在数据库中的数据一般不是我们所需要的字段格式,
-
需要公司名称,同时也需要公司地址,但是这两个数据存储在不同的列中。
-
省,市,县和邮政编码存储在不同的列中,但是当我们需要发快递时,需要将他们组合在一起。
-
某一列的数据是大小写混写的,但是偶尔我们需要全部大写输出。
-
商品信息存储时,我们一般存储的有商品的数量,商品的总价,但是打印发票时我们需要知道商品的总价格。
-
例如,总数,平均数的计算等等。
上述这些例子,都不是应用程序应该做的事情,只需要我们检索时,经过转换,计算过的数据即可。这就是计算字段可以派上的用场。
字段,与列是相同的概念,经常互换使用,不过数据库列一般称为列,而字段这个术语通常在计算字段这种场合下使用。
需要特别注意,只有数据库知道select语句中,哪些列是实际的数据库表列,哪些列为计算字段。但是从客户端看,计算字段和数据库表列是一样的。
在SQL语句内可完成的许多转换和格式化工作都可以直接在客户端应用程序内完成。但一般来说,在数据库服务器上完成这些操作比在客户端中完成要快得多。
7.2-拼接字段
例如:Vendors表包含供应商名和地址信息。假如要生成一个供应商报表,需要在格式化的名称(位置)中列出供应商的位置。
此报表需要一个值,而表中数据存储在两个列vend_name和vend_country中。此外,需要用括号将vend_country括起来,这些东西都没有存储在数据库表中。
拼接:将值联结到一起(将一个值附加到另一个值)构成单个值
解决办法是把两个列拼接起来。在SQL中的SELECT语句中,可使用一个特殊的操作符来拼接两个列。根据你所使用的DBMS,此操作符可用加号(+)或两个竖杠(||)表示,SQL Server使用+号。DB2、Oracle、PostgreSQL和SQLite使用||。在MySQL和MariaDB中,必须使用特殊的函数。
使用加号(+)的例子:
SELECT vend_name + '(' + vend_country + ')'
FROM Vendors
ORDER BY vend_name;
使用两个竖杠(||)的例子:
SELECT vend_name || '(' || vend_country || ')'
FROM Vendors
ORDER BY vend_name;
MySQL或MariaDB时需要使用的语句:
SELECT Concat(vend_name, ' (', vend_country, ')')
FROM Vendors
ORDER BY vend_name;
由结果可以知道,上述语句先取出存储在vend_name中的名称,然后取出vend_country中的国家,然后使用Concat函数进行拼接,拼接后就会输出上述结果。
注意:有些(并不是所有数据库)数据库进行拼接的时候,会输出为列宽,也就是会多很多空格,所以我们需要使用SQL的RTRIM()函数来处理多余的空格。RTRIM()函数去掉值右边的所有空格。
例如:
SELECT vend_name + '(' + RTRIM(vend_country) + ')'
TRIM函数:大多数DBMS都支持RTRIM()(正如刚才所见,它去掉字符串右边的空格)、LTRIM()(去掉字符串左边的空格)以及TRIM()(去掉字符串左右两边的空格)。
7.2.1 使用别名
SQL支持列别名。别名(alias)是一个字段或值的替换名。别名用AS关键字赋予。
select Concat(vend_name,'(',vend_country,')')
as vend_title
from vendors
order vend_name;
查询到的列会将列名设置为vend_title
AS: as子句是可选的,但是如果有计算字段和拼接字段出现的时候,最好使用它,这被视为一条最佳实践。
别名的其他用途 别名还有其他用途。常见的用途包括在实际的表列名包含不合法的字符(如空格)时重新命名它,在原来的名字含混或容易误解时扩充它。
别名 别名的名字既可以是一个单词,也可以是一个字符串,可读性太差,无论是取别名还是取字段名应当见名知意。如果是后者,字符串应该括在引号中。虽然这种做法是合法的,但不建议这么去做。多单词的名字可读性高,不过会给客户端应用带来各种问题。因此,别名最常见的使用是将多个单词的列名重命名为一个单词的名字。
导出列 别名有时候也被称为导出列,代表的是相同的东西。
7.3-使用算术计算
计算字段另一个用途是对检索出的字段进行算术计算。Orders表包含收到的所有订单,OrderItems表包含每个订单中的各项物品。
select prod_id,quantity,item_price
from orderitems
where order_num = 20008;
上述SQL语句检索订单号为20008的所有订单。
检索到的数据中,item_price为商品单价,如果想要计算每种产品的总价。
select prod_id,quantity,item_price,quantity*item_price as total
from orderitems
where order_num = 20008;
通过数量×单价=总价,就可以得到每种产品的总价值。
SQL支持的基本操作符:
如何测试计算 SELECT语句为测试、检验函数和计算提供了很好的方法。虽然SELECT通常用于从表中检索数据,但是省略了FROM子句后就是简单地访问和处理表达式,例如SELECT 3 * 2;将返回6,SELECT Trim(' abc ');将返回abc,SELECT Curdate();使用Curdate()函数返回当前日期和时间。现在你明白了,可以根据需要使用SELECT语句进行检验。
练习
-
别名的常见用法是在检索出的结果中重命名表的列字段(为了符合特定的报表要求或客户需求)。编写SQL语句,从Vendors表中检索vend_id、vend_name、vend_address和vend_city,将vend_name重命名为vname,将vend_city重命名为vcity,将vend_address重命名为vaddress。按供应商名称对结果进行排序(可以使用原始名称或新的名称)。
select vend_id,vend_name as vname,vend_address as vaddress,vend_city as vcity from vendors order by vname;
-
我们的示例商店正在进行打折促销,所有产品均降价10%。编写SQL语句,从Products表中返回prod_id、prod_price和sale_price。sale_price是一个包含促销价格的计算字段。提示:可以乘以0.9,得到原价的90%(即10%的折扣)。
select prod_id,prod_price,prod_price*0.9 as sale_price from products;