您的位置:首页 > 数据库

[SQL] SQL 基础知识梳理(六)- 函数、谓词、CASE 表达式

2017-03-21 09:44 627 查看

SQL 基础知识梳理(六)- 函数、谓词、CASE 表达式

-- DDL:创建表
CREATE TABLE TenpoShohin
(tenpo_id  CHAR(4)       NOT NULL,
tenpo_mei  VARCHAR(200) NOT NULL,
shohin_id CHAR(4)       NOT NULL,
suryo     INTEGER       NOT NULL,
PRIMARY KEY (tenpo_id, shohin_id));

-- DML:插入数据

INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000A',    '东京',        '0001',    30);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000A',    '东京',        '0002',    50);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000A',    '东京',        '0003',    15);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000B',    '名古屋',    '0002',    30);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000B',    '名古屋',    '0003',    120);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000B',    '名古屋',    '0004',    20);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000B',    '名古屋',    '0006',    10);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000B',    '名古屋',    '0007',    40);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000C',    '大阪',        '0003',    20);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000C',    '大阪',        '0004',    50);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000C',    '大阪',        '0006',    90);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000C',    '大阪',        '0007',    70);
INSERT INTO TenpoShohin (tenpo_id, tenpo_mei, shohin_id, suryo) VALUES ('000D',    '福冈',        '0001',    100);


测试数据







  7.EXIST

  很多时候基本上可以使用 IN 或 NOT IN 来代替该谓词。

  作用:判断是否存在满足某种条件的记录。





  NOT EXIST 与 EXIST 相反,不存在:



三、CASE 表达式

  1.CASE 表达式:(条件)分歧。

  2.语法

--语法
--CASE WHEN <判断表达式> THEN <表达式>
--     WHEN <判断表达式> THEN <表达式>
--     ...
--     ELSE <表达式>
--END


  判断表达式类似“键 = 值”的形式,返回值为真值(TRUE/FALSE/UNKNOW)的表达式。如果结果为真,就会返回 THEN 子句中的表达式;如果不为真,就跳转到下一条 WHEN 子句的判断中;如果到最后的 WHEN 子句都不为真,就执行最后一条 ELSE 的表达式。



  下面是简化版的 CASE 表达式:



  3.行转列





备注

  这里采用 MS SQL Server 进行验证,不保证所有的 DBMS 执行结果正确。

《SQL 基础知识梳理》系列

  《SQL 基础知识梳理(一) - 数据库与 SQL

  《SQL 基础知识梳理(二) - 查询基础

  《SQL 基础知识梳理(三) - 聚合和排序

  《SQL 基础知识梳理(四) - 数据更新

  《SQL 基础知识梳理(五) - 复杂查询

  《SQL 基础知识梳理(六)- 函数、谓词、CASE 表达式

  《SQL 基础知识梳理(七)- 集合运算

【博主】反骨仔

【原文】http://www.cnblogs.com/liqingwen/p/6572284.html


【参考】《SQL ゼロからはじめるデータベース操作》
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: