SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数

时间:2022-02-18 02:28:12

所谓函数,
就是输入某一值得到相应输出结果的功能,输入值称为参数(parameter)
输出值称为返回值

算术函数

为了学习算术函数,我们首先根据代码清单 6-1 创建一张示例用表
SampleMath
)。

由于 PostgreSQL 中的 ROUND函数只能使用 NUMERIC 类型的数据,因此我们在示例中也使用了该数据类型。

SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数
--Mysql
--DDL:创建表
CREATE TABLE SampleMath
(m  NUMERIC (10,3),
 n  INTEGER,
 p  INTEGER);

--DML:插入数据
START TRANSACTION;

INSERT INTO SampleMath(m, n, p) VALUES (500,  0,    NULL);
INSERT INTO SampleMath(m, n, p) VALUES (-180, 0,    NULL);
INSERT INTO SampleMath(m, n, p) VALUES (NULL, NULL, NULL);
INSERT INTO SampleMath(m, n, p) VALUES (NULL, 7,    3);
INSERT INTO SampleMath(m, n, p) VALUES (NULL, 5,    2);
INSERT INTO SampleMath(m, n, p) VALUES (NULL, 4,    NULL);
INSERT INTO SampleMath(m, n, p) VALUES (8,    NULL, 3);
INSERT INTO SampleMath(m, n, p) VALUES (2.27, 1,    NULL);
INSERT INTO SampleMath(m, n, p) VALUES (5.555,2,    NULL);
INSERT INTO SampleMath(m, n, p) VALUES (NULL, 1,    NULL);
INSERT INTO SampleMath(m, n, p) VALUES (8.76, NULL, NULL);

COMMIT;


--确认表中的内容
SELECT * FROM SampleMath;
View Code --Mysql

SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数

ABS——绝对值
ABS 是计算绝对值的函数。 绝对值absolute value)不考虑数值的符号,表示一个数到原点的距离。 
SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数
MOD——求余
SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数
ROUND——四舍五入
SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数

SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数

 

字符串函数
在日常生活中,我们经常会像使用数字那样,对字符串进行替换、截
取、简化等操作,因此 SQL 也为我们提供了很多操作字符串的功能。
为了学习字符串函数,我们再来创建一张表(SampleStr),参见代码清单 6-5

 

SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数
--MySQL
--DDL:创建表
CREATE TABLE SampleStr
(str1  VARCHAR(40),
 str2  VARCHAR(40),
 str3  VARCHAR(40));

--DML:插入数据
START TRANSACTION;

INSERT INTO SampleStr (str1, str2, str3) VALUES (opx,            rt    ,    NULL);
INSERT INTO SampleStr (str1, str2, str3) VALUES (abc    ,    def    ,    NULL);
INSERT INTO SampleStr (str1, str2, str3) VALUES (山田    ,    太郎  ,    是我);
INSERT INTO SampleStr (str1, str2, str3) VALUES (aaa    ,    NULL    ,    NULL);
INSERT INTO SampleStr (str1, str2, str3) VALUES (NULL    ,    xyz,            NULL);
INSERT INTO SampleStr (str1, str2, str3) VALUES (@!#$%,    NULL    ,    NULL);
INSERT INTO SampleStr (str1, str2, str3) VALUES (ABC    ,    NULL    ,    NULL);
INSERT INTO SampleStr (str1, str2, str3) VALUES (aBC    ,    NULL    ,    NULL);
INSERT INTO SampleStr (str1, str2, str3) VALUES (abc太郎,    abc    ,    ABC);
INSERT INTO SampleStr (str1, str2, str3) VALUES (abcdefabc,   abc    ,    ABC);
INSERT INTO SampleStr (str1, str2, str3) VALUES (micmic,          i,        I);

COMMIT;


--确认表中的内容
SELECT * FROM SampleStr;
View Code --MySQL

 

 

SQL基础教程(第2版)第6章 函数、谓词、CASE表达式:6-1 函数