《SQL必知必会》笔记4-计算字段、函数处理文本、日期、数值数据

1 创建计算字段

1.1 计算字段

存储在数据库表中的数据,一般不是应用程序所需要的格式。

比如:

  • 需要显示公司名,同时还要显示公司的地址,但这两个信息存储在不同的列表中。
  • 城市、州和邮政编码存储在不同的列中,但邮件标签打印程序需要把它们作为一个有恰当格式的字段检索出来。
  • 列数据是大小写混合的,但报表程序需要把所有数据按大写表示出来。
  • 物品订单表存储物品的价格和数量,不存储每个物品的总价格,单位打印发票,需要物品的总价格。
  • 需要根据表数据进行诸如总数、平均数的计算。

在上述这些例子中,存储在表中的数据都不是应用程序所需要的。我们需要从数据库中检索出转换、计算或格式化过的数据,而不是检索出数据,然后在客户端应用程序中重新格式化。

字段(field):基本上与列(column)的意思相同,经常互换使用,不过数据库列一般称为列,而术语字段通常与计算字段一起使用。


1.2 拼接字段

拼接(concatenate):将值连接到一起(将一个值附加到另一个值)构成单个值。

Access和SQL Server使用加号(+),DB2、Oracle、PostgreSQL和SQLite使用两个竖杠(||),MySQL、MariaDB使用concat函数。

生成供应商报表,显示出vend_name和vend_country,并且将vend_country括起来。

SELECT vend_name + '(' + vend_country + ')'
FROM Vendors 
ORDER BY vend_name;

SELECT vend_name || '(' || vend_country || ')'
FROM Vendors 
ORDER BY vend_name;

SELECT concat(vend_name, '(', vend_country, ')')
FROM Vendors 
ORDER BY vend_name;

上面SELECT语句拼接以下元素:

  1. 存储在vend_name列中的名字。
  2. 包含一个空格和一个左圆括号的字符串。
  3. 存储在vend_country列中的国家。
  4. 包含一个右圆括号的字符串。

有些数据库返回的结果会包含空格,也就是圆括号里的内容是右对齐的,所以为消除这种右对齐现象。可以使用rtrim()函数。(MySQL中不会出现右对齐现象。)

SELECT concat(rtrim(vend_name), '(', rtrim(vend_country), ')')
FROM Vendors 
ORDER BY vend_name;

rtrim()去掉字符串右边的空格,ltrim()去掉字符串左边的空格,trim()去掉字符串左右两边的空格。

在上例中,我们可以看到显示的列字段的名字,是SELECT后的检索字段,比如显示为concat(vend_name, '(', vend_country, ')'),怎么让它显示为合适的字段呢?使用别名。

别名(alias)是一个字段或值的替换名。别名用AS关键字赋予。

SELECT concat(rtrim(vend_name), '(', rtrim(vend_country), ')') 
        AS vend_title
FROM Vendors 
ORDER BY vend_name;

1.3 执行算数计算

检索订单号为20008中的所有物品:

SELECT prod_id, quantity, item_price 
FROM OrderItems
WHERE order_num = 20008;

汇总物品价格:

SELECT prod_id, quantity, item_price, 
       quantity * item_price AS expanded_price
FROM OrderItems 
WHERE order_num = 20008;

2 使用函数处理数据(文本、日期、数值)

大多数SQL实现支持以下类型的函数:

  1. 用于处理文本字符串(如删除或填充值,转换值为大写或小写)的文本函数。
  2. 用于在数值数据上进行算数操作(如返回绝对值,进行代数运算)的数值函数。
  3. 用于处理日期和时间值并从这些值中提取特定成分(如返回两个日期之差,检查日期有效性)的日期和时间函数。
  4. 返回DBMS正使用的特殊信息(如返回用户登录信息)的系统函数。

2.1 文本处理函数

常用的文本处理函数

函数 说明
left() 返回字符串左边的字符
right() 返回字符串右边的字符
ltrim() 去掉字符串左边的空格
rtrim() 去掉字符串右边的空格
lower() 将字符串转换为小写
upper() 将字符串转换为大写
length() 返回字符串的长度
soundex() 返回字符串的SOUNDEX值
SELECT vend_name, upper(vend_name) AS vend_name_upcase
FROM Vendors 
ORDER BY vend_name;

soundex()指的是两个字符串的发音相似。

SELECT cust_name, cust_contact 
FROM Customers
WHERE soundex(cust_contact) = soundex('Michael Green');

因为Michael Green和Michelle Green发音相似,所以它们的soundex值匹配,因此WHERE子句可以正确地过滤出所需数据。


2.2 日期和时间处理函数

日期和时间值一特殊的格式存储,以便能快速和有效地排序或过滤,并且节省物理存储空间。

Orders表中包含的订单都带有订单日期,在SQL Server中检索2012年的所有订单。

SELECT order_num 
FROM Orders
WHERE datepart(yy, order_date) = 2012;

在Access中:

SELECT order_num 
FROM Orders
WHERE datepart('yyyy', order_date) = 2012;

MySQL和MariaDB可以使用year()函数从日期中提取年份。

SELECT order_num, order_date 
FROM Orders
WHERE year(order_date) = 2012;

可以看到,不同DBMS的日期和时间处理函数是不同的,在处理的时候,要参考相应的文档。


2.3 数值处理函数

数值处理函数仅处理数值数据,这些函数主要用于代数、三角或几何运算,因此不想字符串或日期-时间处理函数使用那么频繁。

常用的数值处理函数

函数 说明
PI() 返回圆周率
ABS() 返回一个数的绝对值
EXP() 返回一个数的指数值
SQRT() 返回一个数的平方根
SIN() 返回一个角度的正弦
COS() 返回一个角度的余弦
TAN() 返回一个角度的正切

下面的只是一个例子,没有实际意义,只是为了说明可以用数值处理函数处理数值数据。


如果您发现文中有不清楚或者有问题的地方,请在下方评论区留言,我会根据您的评论,更新文中相关内容,谢谢!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容

  • SQL与MySQL简介 数据库基础 从SQL的角度来看,数据库就是一个以某种有组织的方式存储的数据集合。我们可以采...
    heming阅读 3,074评论 1 8
  • 数据库入门 数据库: 保存有组织的数据的容器(通常是一个文件或一组文件).数据库软件应该称为 DBMS(DataB...
    Mjericho阅读 498评论 0 0
  • 题目 Given a string s, partition s such that every substrin...
    时光杂货店阅读 127评论 0 0
  • 小姑打电话给我,抱怨奶奶非要侍弄她田里的庄稼,谁都劝不住。 我在电话这头百感交集:“你没有问她为什么一定要这样吗?...
    执明珠魅阅读 236评论 0 0
  • 西秦木子抒情诗集《守望者》目录 又一个春天过去 南方的梅雨消停 初夏的骄阳如硕大的花朵 进入万物内部 发霉的一切即...
    西秦木子阅读 234评论 1 6