SELECT * FROM SYS_COMPANY_DEPT t FETCH FIRST 1 ROWS only;
--要求排序顺序:2,3,0,1
SELECT * FROM SYS_COMPANY_DEPT t
ORDER BY (CASE t.DEPT_LEVEL WHEN '2' THEN 1 WHEN '3' THEN 2 WHEN '0' THEN 3 WHEN '1' THEN 4 ELSE t.DEPT_LEVEL end)
--要求排序顺序:2,3,0,1
SELECT decode(t.DEPT_LEVEL,'2',1,'3',2,'0',3,'1',4), t.*
FROM SYS_COMPANY_DEPT t
ORDER BY decode(t.DEPT_LEVEL,'2',1,'3',2,'0',3,'1',4)
||
" 或者 concat
函数,如下:SELECT 'aa' ,'aa'||'-bb',CONCAT('cc','@dd')
FROM "SYSIBM".SYSDUMMY1 s ;
SELECT CAST(123.66666 AS decimal(10,2)), cast(date('2023-12-31') AS int) num_1
FROM "SYSIBM".SYSDUMMY1 s ;
SELECT round(0.6666,2) num_1,
(2/3) num_2, --与oracle不同
round(2/3,2) num_3, --与oracle不同
round(2/3) num_4,
round(0.3333,2)
FROM "SYSIBM".SYSDUMMY1 s ;
-- 结果对比
SELECT round(0.6666,2) num_1,--正常四舍五入
(2/3) num_2,--0 数据不对
round(2/3,2) num_3,--0 数据不对
CAST((2/3) AS decimal(10,2)) num_4,--0 数据不对
CAST(2 AS decimal)/3 num_5,--0.66666666666666666666666666
cast(CAST(2 AS decimal)/3 AS decimal(10,2)) num_6,--保留2位小数,不四舍五入
cast(round(CAST(2 AS decimal)/3,2) AS decimal(10,2)) num_7,--round(CAST(2 AS decimal)/3,2) 使用cast让计算结果正常,使用round保留2位小数
round(CAST(2 AS decimal)/3,2) num_8 --优化一下 num_7 的写法,最外层直接round处理即可
FROM "SYSIBM".SYSDUMMY1 s ;
--实现四舍五入最终SQL
SELECT round(0.6666,2) num_1,--正常四舍五入,但是只处理没有计算过程的数据
cast(round(CAST(2 AS decimal)/3,2) AS decimal(10,2)) num_7,--round(CAST(2 AS decimal)/3,2) 使用cast让计算结果正常,使用round保留2位小数
round(CAST(2 AS decimal)/3,2) num_8 --优化一下 num_7 的写法,最外层直接round处理即可
FROM "SYSIBM".SYSDUMMY1 s ;
dec()
函数单独使用,如下:SELECT
dec(0.6666,10,2) num_1,--保留2位,但不四舍五入
dec(0.6666 + 0.5) num_2,--四舍五入 且 保留整数
dec(0.6666 + 0.05,10,1) num_3,--四舍五入 且 保留1位
dec(0.6666 + 0.005,10,2) num_4,--四舍五入 且 保留2位
dec(0.6666 + 0.0005,10,3) num_5,--四舍五入 且 保留3位
dec(2/3) num_6,
dec(2/3 + 0.0005,10,3) num_7
from "SYSIBM".SYSDUMMY1 s ;
dec()
+ cast()
结合使用SELECT
dec(2/3) num_6,
dec(2/3 + 0.0005,10,3) num_7,
dec(CAST(2 AS decimal)/3 ,10,2) num_8, --保留2位,但不四舍五入
dec(CAST(2 AS decimal)/3 + 0.5) num_9, --四舍五入 且 保留整数
dec(CAST(2 AS decimal)/3 + 0.05 ,10,1) num_10, --四舍五入 且 保留1位
dec(CAST(2 AS decimal)/3 + 0.005 ,10,2) num_11 --四舍五入 且 保留3位
from "SYSIBM".SYSDUMMY1 s ;
nvl()
函数的意思,如下:SELECT NULL,COALESCE(NULL,'')
from "SYSIBM".SYSDUMMY1 s ;
--rtrim 去掉字符串右边的空格
--ltrim 去掉字符串左边的空格
--trim 去掉字符串左右两边的空格
SELECT trim(' abc '),ltrim(' abc '),rtrim(' abc '),length(rtrim(' abc ')),length(trim(' abc '))
from "SYSIBM".SYSDUMMY1 s ;
SELECT
SUBSTR('abcdef',2,3) , --从第二个字符开始截取,截取3个字符
SUBSTR('123456',2,LENGTH('123456')-2), --截掉前后的字符
SUBSTR('123456',LENGTH('123456')-1,2) --只截取最后两个字符
FROM "SYSIBM".SYSDUMMY1 s ;
SELECT
left('123456',3), --截取前3个
RIGHT('123456',2) --截取后2个
FROM "SYSIBM".SYSDUMMY1 s ;