SQL基础学习_05_函数、谓词、CASE表达式
函数
算术函数
1. 四则运算: +、-、*、/
2. ABS:求绝对值, ABS(数值)
3. MOD: 求余,MOD(被除数,除数)
4. ROUND:四舍五入,ROUND(对象数值,保留小数的位数)
字符串函数
1. 字符串拼接: ||, str1 || str2 || str3 || … || strn AS str_all
2. 字符串长度:LENGTH,LENGTH(str1) AS len_str1
3. 小写转换:LOWER,LOWER(str1) AS low_str
4. 大写转换:UPPER,UPPER(str1) AS up_str
5. 字符串替换:REPLACE,REPLACE(替换对象, 被替换的字符串, 替换后的字符串) AS rep_str :如果替换对象中不含有被替换字符串,则不进行替换操作
6. 字符串截取:SUBSTRING,SUBSTRING(对象字符串 FROM 起始位置 FOR 截取的长度) AS sub_str
日期函数
1. CURRENT_DATE:不需要参数,直接返回当前日期,显示格式:yyyy-mm-dd
2. CURRENT_TIME:不需要参数,直接返回当前时间,显示格式:hh:mm:s
3. CURRENT_TIMESTAMP:不需要参数,同时获得日期和时间,也可以进行截取操作
4. EXTRACT:截取时间,EXTRACT(日期元素 FROM 日期)
日期元素有:YEAR、MONTH、DAY、HOUR、MINUTE、SECOND
例如:
SELECT CURRENT_TIMESTAMP
EXTRACT(YEAR FROM CURRENT_TIMESTAMP) AS year,
EXTRACT(MONTH FROM CURRENT_TIMESTAMP) AS month,
EXTRACT(DAY FROM CURRENT_TIMESTAMP) AS day,
EXTRACT(HOUR FROM CURRENT_TIMESTAMP) AS hour,
EXTRACT(MINUTE FROM CURRENT_TIMESTAMP) AS minute,
EXTRACT(SECOND FROM CURRNR_TIMESTAMP) AS second;
转换函数
1. CAST( 转换前的值 AS 想要转换的数据类型 )
例如:
SELECT CAST(‘0001’ AS INTEGER ) AS int_col; SQL Server/ PostgreSQL
SELECT CAST(‘0001’ AS SIGNED INTEGER) AS int_col; MySQL
SELECT CAST(‘0001’ AS INTEGER) AS int_col FROM DUAL; Oracle
SELECT CAST(‘0001’ AS INTEGER) AS int_col FROM SYSIBM.SYSDUMMY1; DB2
结果:
int_col
—————
1
2. COALESCE(数据1,数据2,数据3 ……) 返回左侧开始第一个不是NULL的值
谓词
LIKE
like谓词用于查询字符串部分一致,类似于简化版正则表达式,其中%表示匹配任意字符任意格式,_表示匹配一个任意字符串
例如:
查询SampleLike表中,strcol列字符串中间含有ddd的行
SELECT *
FROM SampleLike
WHERE strcol LIKE ‘%ddd%'
其他类似于:’%ddd’ ,’ddd%’ , ‘_ddd’ 等简单模式的匹配
BETWEEN
相当于 >= AND <=,例如:
SELECT shohin_mei, hanbai_tanka
FROM Shohin
WHERE hanbai_tanka BETWEEN 100 AND 1000
IS NULL 、 IS NOT NULL
用于判断是否为NULL值
IN
将多个OR条件合并,如:
SELECT shohin_mei, shiire_tanka
FROM Shohin
WHERE shiire_tanka NOT IN (320, 500, 5000)
注意:IN和NOT IN无法选取NULL值,NULL的判断只能用IS NULL 和IS NOT NULL
配合子查询中返回多个值,可以灵活使用IN谓词来做选择
如:
SELECT shohin_mei, hanbai_tanka
FROM Shohin
WHERE shohin_id IN (SELECT shohin_id
FROM TenpoShohin
WHERE tenpo_id = ‘000C')
EXIST
EXIST谓词用于判断是否存在满足某种条件的记录,多用于在子查询中替换IN达到相同目的的操作,如:
SELECT shohin_mei, hanbai_tanka
FROM Shohin AS S
WHERE EXISTS ( SELECT *
FROM TenpoShohin AS TS
WHERE TS.tenpo_id = ‘000C’
AND TS.shohin_id = S.shohin_id)
ps. 个人感觉还是IN比较直观易用一些
CASE表达式
相当于switch语句,语法为:
CASE <表达式>
WHEN <表达式> THEN <表达式>
WHEN <表达式> THEN <表达式>
...
ELSE <表达式>
END
每一个WHEN 、THEN组合相当于switch中的一个case,最后的ELSE相当于default;
CASE表达式常和SELECT结合:
SELECT <列>,
CASE WHEN <表达式> THEN <表达式>
WHEN <表达式> THEN <表达式>
…
ELSE NULL
END AS <名称>
FROM <表>;
SQL基础学习_05_函数、谓词、CASE表达式的更多相关文章
- 楼梯T-SQL:超越基础6级:使用CASE表达式和IIF函数
从他的楼梯到T-SQL DML,Gregory Larsen涵盖了更多的高级方面的T-SQL语言,如子查询. 有时您需要编写一个可以根据另一个表达式的评估返回不同的TSQL表达式的单个TSQL语句. ...
- SQL 基础学习(2) Joining 和function , 作业没有做,需要看百宝箱。NOsql的概念
SQL 基础学习(2) Joining 可以同时关联(joining)多张表进行复杂的查询. 相比于用Rails捞出数据再用Ruby进行过滤组合,使用SQL更加高效,节能. 以下是 users has ...
- Oracle SQL 基础学习
oracel sql 基础学习 CREATE TABLE USERINFO ( ID ,) PRIMARY KEY, USERNAME ), USERPWD ), EMAIL ), REDATE DA ...
- SQL 基础命令和函数
[数据操作] SELECT --从数据库表中检索数据行和列 INSERT --向数据库表添加新数据行 DELETE --从数据库表中删除数据行 UPDATE --更新数据库表中的数据 [数据定义] C ...
- Node.js系列基础学习-----回调函数,异步
Node.js基础学习 Node.js回调函数 Node.js异步编程的直接体现就是回调,异步编程依托回调来实现,但不是异步.回调函数在完成任务后就会被调用,Node有很多的回调函数,其所有的API都 ...
- SQL基础学习篇--字符函数
字符函数可与SELECT,UPDATE,DELETE RIGHT()----从右侧开始选择 SELECT RIGHT(列,字符数量) FROM 表 LEFT()----从左侧开始选择 SUBSTR ...
- SQL 基础学习(1):下载DB Browser for SQLite. 下载graphviz(为了使用Rails ERD的前提)出现❌,已debug.
SQL is a standard language for storing, manipulating and retrieving data in databases. 关系型数据库:RDBMS( ...
- python基础学习2 函数变量与赋值
学习的第一步,就是通常的输出函数:print() 1.基础主要学习了变量的赋值,变量名可以疑字母.数字.下划线(_)进行命名,但是不能以数字开头 变量的赋值:变量名 = 变量值 2.模块的导入,和调用 ...
- SQL基础学习_04_视图
视图 1. 视图的创建 视图就是保存好的SELECT语句,这些SELECT语句执行之后会产生新的表,所以在SQL中,视图和表是不做差别对待的,也就是SQL也可以对视图做一些操作: 由于 ...
随机推荐
- centos 下安装pptp (vpn) 的方法
废话少说 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 3 ...
- 用echartsjs 实现动态绘制折线、柱状等图形,并实现多图联动效果
echarts对于大数据处理后绘制折线图,柱形图等等的效果和速度都很好.下面我们介绍 怎么把封装的数据列表解析出来,动态绘图,并且实现鼠标联动效果引入js文件: <script type=&qu ...
- Guice之IOC教程
Guice 在上一篇博客中, 我们讲解了Spring中的IOC示例与实现, 本文着重介绍Guice注入以及与Spring中的差异. Guice是Google开发的, 一个轻量级的依赖注入框架, 跟Sp ...
- HTMLCSS实现左侧固定宽度右侧内容可滚动
在做移动端页面的时候,经常会碰到一个div中分左右两个div,左侧div固定宽度或百分比,右侧div中内容左右溢出,需要左右滑动才可以浏览到全部内容,为此写了一个demo. 处理这个问题的核心关键点是 ...
- Progressive Web Apps入门
PC和Mobile开发技术演进 PC方向,从客户端到富客户端,到现在广泛使用的Web. 移动方向,目前主要还是原生应用和Mobile Web,PWA相关技术是未来发展方向. PWA的概念 ...
- Arrays.asList()生成的List抛UnsupportedOperationException分析
一.背景:使用工具类 Arrays.asList()把数组转换成集合时,使用其修改集合相关的方 法,它的 add/remove/clear 方法会抛出 UnsupportedOperationExce ...
- XML约束(3)
本节要点: 了解XML的约束模式 了解DTD 了解Schema 1 了解XML的约束模式 计算机程序在处理XML文档之前,必须能够解析出XML文档的内容中各个元素的相关信息.将解析出来的信息再交给下游 ...
- 如何在华为云软件开发云上搭建JavaWeb,Maven项目
本文将使用华为云软件开发云向大家演示如何搭建JavaWeb,Maven项目. 一.相关信息 1.华为云软件开发云简介 华为云软件开发云(DevCloud)是集华为近30年研发实践,前沿研发理念,先进研 ...
- 自学Zabbix3.9.2-模板Templates-linking/unlinking
自学Zabbix3.9.2-模板Templates-linking/unlinking HOST链接模板之后,便继承了模板里定义的item,trigger等等,使用这个方法,配置zabbix监控会减少 ...
- Github开源项目(企业信息化基础平台)
JEEPlatform 一款企业信息化开发基础平台,可以用于快速构建企业后台管理系统,集成了OA(办公自动化).SCM(供应链系统).ERP(企业资源管理系统).CMS(内容管理系统).CRM(客户关 ...