《SQL 基础教程》第六章:函数、谓词、CASE 表达式
函数是 SQL 中的一部分.在 SQL 中,除了普通的函数之外,还有特殊的函数(谓词和 CASE 表达式)用于各种情况.
函数
函数的种类有:
- 算术函数
- 字符串函数
- 日期函数
- 转换函数(用于转换数据类型)
- 聚合函数
算术函数
例如;
- MOD:求余
- ABS:求绝对值
- ROUND:四舍五入
字符串函数
例如:
- 拼接: || 函数
- 求字符串长度: LENGTH
- 大小写转换:LOWER ,UPPER
- 替换字符串:REPLACE(对象字符串,对象字符串中要替换的字符串,替换成的字符串)
日期函数
例如:
- 得到当前日期:CURRENT_DATE
- 得到当前时间(时分秒):CURRENT_TIME
- 得到当前的日期和时间: CURRENT_TIMESTAMP
- 截取日期元素:EXTRACT(YEAR FROM CURRENT_TIMESTAMP)
转换函数
1.CAST 函数
格式:
CAST(转换前的值 AS 想要转换成的数据类型)
范例:
CAST('0001' AS INTEGER)
2.COALESCE 函数
格式:
COALESCE(num1, num2, num3, num4,...)
功能:
返回从左侧起第一额不是 NULL 的值.
Predicate 谓词
是进行判断的函数,该函数的返回值有两种:真和假.典型的谓词,例如: =,>,<等比较运算符就是比较谓词.
LIKE 谓词——模式匹配
格式:
SELECT *
FROM SampleLIke
WHERE strcol LIKE 'ddd%'
功能:
查找特定文本模式的字符串,可用的符号有:
- %:代表任意字符串
- _:代表任意一个字符
BETWEEN 谓词——范围查询
格式:
SELECT product_name, sale_price
FROM Product
WHERE sale_price BETWEEN 100 AND 1000
功能:
判断数据是否在某一区间范围内
IS NULL, IS NOT NULL ——判断是否为 NULL
IN 谓词——判断 OR 类型的数据
格式:
SELECT product_name, purchase_price
FROM Product
WHERE purchase_price IN (320, 500, 5000);
功能:
取出符合 OR 语句要求的数据
IN 谓词与子查询
子查询可以与 IN 谓词配合起来,从而实现动态的查询,编写出更加易维护的程序,例如:
用于查询shop_id 为 '000C'所含的商品.
SELECT product_name, sale_price
FROM Product
WHERE product_id IN (SELECT product_id
FROM ShopProduct
WHERE shop_id = '000C');
EXIST 谓词——判断是否存在满足条件的记录
范例:
查找 P 表和 SP 表中 shop_id 相同的数据:
SELECT product_name, sale_price
FROM Product AS P
WHERE EXIST (SElECT *
FROM ShopProduct AS SP
WHERE SP.shop.id = P.product_id);
格式:
其中的 SELECT * 是 SQL 的一种惯例.
EXIST 只关心是否有匹配的数据,因此 SELECT * 改为 SELECT 1 的时候结果也不会发生变化.
功能:
EXISTS 谓词常常与关联子查询配合而进行查询,返回满足条件的记录.
CASE 表达式
CASE 表达式分为简单 CASE 表达式与搜索 CASE 表达式,其区别是:
- 简单 CASE 表达式最初的 "CASE
<colname>“会作为谓词的左边的对象. - 搜索 CASE 表达式无此限制,因此可以使用多种判断的条件
「简单 CASA 表达式」格式:
CASE <表达式>
WHEN <含谓词的表达式> THEN <表达式>
WHEN <含谓词的表达式> THEN <表达式>
WHEN <含谓词的表达式> THEN <表达式>
...
ELSE <表达式>
END
「搜索 CASA 表达式」格式:
CASE WHEN <含谓词的表达式> THEN <表达式>
WHEN <含谓词的表达式> THEN <表达式>
WHEN <含谓词的表达式> THEN <表达式>
...
ELSE <表达式>
END
其中第一个表达式是包含谓词的表达式,其返回 TURE/FALSE/UNKNOWN),
第二个表达式是第一个表达式为 TRUE 的时候,执行的语句.
「搜索 CASA 表达式」语法:
CASE 表达式顺序执行语句,如果表达式返回 TRUE, 则执行 THEN 后的语句,然后 CASE 表达式的执行到此为止.
如果不为 TRUE, 则执行下面的 WHEN 语句
当所有 WHEN 语句执行完(都不为 TRUE)后,执行 ELSE 语句,然后 CASE 表达式的执行到此为止.
ELSE 语句是可选的, 默认情况下为 ELSE NULL
《SQL 基础教程》第六章:函数、谓词、CASE 表达式的更多相关文章
- Objective-C 基础教程第六章,源文件组织
目录 Object-C 基础教程第六章,源文件组织 0x00:前言 0x01:Xcode创建OC类 0x02:Xcode群组 0x03 Xcode跨文件依赖关系 @class关键字 导入和继承 小结 ...
- 《SQL 基础教程》第二章:查询基础
这一章的结构如下: SELECT 语句基础 算术运算符和比较运算符 逻辑运算符 SELECT 语句可用于查询数据,并且可以设定条件来查询具有特定值的记录.条件的设定就需要算数运算符.比较运算符和逻辑运 ...
- 《SQL 基础教程》—第一章:数据库与 SQL
导言 这一章的内容如下: 数据库简介 SQL 概要 表的创建 表的删除与更新 数据库简介 定义: Database, 是大量数据的集合Database Management System,是用于管理数 ...
- 《SQL基础教程》+ 《SQL进阶教程》 学习笔记
写在前面:本文主要注重 SQL 的理论.主流覆盖的功能范围及其基本语法/用法.至于详细的 SQL 语法/用法,因为每家 DBMS 都有些许不同,我会在以后专门介绍某款DBMS(例如 PostgreSQ ...
- 《SQL基础教程》
Product表 CREATE TABLE Product (product_id CHAR(4) NOT NULL, product_name VARCHAR(100) NOT NULL, prod ...
- [SQL基础教程] 3-4 对查询结果进行排序/ORDER BY
[SQL基础教程] 3-4 对查询结果进行排序/ORDER BY ORDER BY SELECT <列名1>,<列名2>,<列名2>... FROM ORDER B ...
- [SQL基础教程] 3-3 HAVING
[SQL基础教程] 3-3 HAVING HAVING子句 SELECT col_1,col_2 FROM table GROUP BY col_1,col_2 HAVING col_1 = '2'; ...
- [SQL基础教程] 3-2 对表进行分组
[SQL基础教程] 3-2 对表进行分组 GROUP BY SELECT <列名1>,<列名2>,... FROM <表名> GROUP BY <列名1> ...
- [SQL基础教程] 3-1 对表进行聚合查询
[SQL基础教程] 3-1 对表进行聚合查询 聚合函数 用于合计的函数称为聚合函数或者集合函数 COUNT SUM AVG MAX MIN SELECT COUNT(*) FROM table; SE ...
- GSAP JS基础教程--使用缓动函数
今天来了解一下缓动easeing函数. 开始,如果你还没有GSAP的类包,可以到GreenSock的官网去下载最新版本的类包,或者直接点击这里来下载 学习之前,先来准备一下: <!DO ...
随机推荐
- table的thead,tbody,tfoot
为了让大表格(table)在下载的时候可以分段的显示,就是说在浏览器解析HTML时,table是作为一个整体解释的,使用tbody可以优化显示. 如果表格很长,用tbody分段,可以一部分一部分地显示 ...
- C++ 用三元组表示法存储稀疏矩阵
若有一个矩阵(m*n),其中非0元素个数远少于数值为0的元素个数,若开辟一个m*n大空间,来存储这样一个很多元素值为0的矩阵,浪费空间,于是我们只存储这些非0的元素的下标及数值 用一个结构体——三元组 ...
- MyEclipse破解步骤
1.下载安装(注:安装后不要打开myeclipse,以下步骤完成方可打开) 2.解压破解文件 3.打开文件夹patch 3.全部复制 4.找到myeclipse的安装目录,打开plugins文件夹 5 ...
- matlab多个曲面如何画在一个坐标系中的疑问
matlab多个曲面如何画在一个坐标系中的疑问 [复制链接] [X,Y]=meshgrid(-3:0.1:3);Z=X.^2+Y.^2;mesh(X,Y,-Z)hold onmesh(X,Y,Z)
- Lintcode: Knight Shortest Path
Given a knight in a chessboard (a binary matrix with 0 as empty and 1 as barrier) with a source posi ...
- github仓库的初步使用
github是被戏称为男人们的朋友圈,在github里可以很方便的和同伴合作.以下是github初步建立的步骤.(由于我已经安装好了,所有没有插入图片,如果有未降到的问题先自行百度,如果我后续碰到有关 ...
- Java之.jdk卸载-Linux
Java之.jdk卸载-Linux 卸载Linux自带的jdk 首先查询: # rpm -qa | grep jdk 使用root账户,进行卸载: # yum -y remove xxxxxxxx( ...
- 【ASP.NET Core】在CentOS上安装.NET Core运行时、部署到CentOS
第一步:Add the dotnet product feed sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc ...
- 记录心得-shiro框架demo示例
从懵懂到了解,再到熟悉,是一个进步的过程! 先撸代码,跑起来看效果,再做详细的介绍,开始干活! 1,先列出工程目录结构,自己需要创建对应层级的程序和相关配置文件. 2,导入maven依赖的jar包.打 ...
- Oracle创建表空间、表、一级用户授权
---恢复内容开始--- 1. 安装: 百度一下你就知道 2. sqlplus登录/sqlplus命令登录 在安装Oracle时,你需要记住设置的“全局数据库名”(默认为orcl) 和 口令,在以两种 ...