oracle⽐较三个数⼤⼩的函数,MySQL与Oracle差异⽐较之三
函数
编号
类别
ORACLE
MYSQL
注释
1
数字函数
round(1.23456,4)
round(1.23456,4)
⼀样:
ORACLE:select round(1.23456,4) value from dual
html网页模板怎么改成自己的MYSQL:select round(1.23456,4) value
2
abs(-1)
abs(-1)
功能: 将当前数据取绝对值
⽤法: oracle和mysql⽤法⼀样
mysql: select abs(-1) value
oracle: select abs(-1) value from dual
3
ceil(-1.001))
ceiling(-1.001)
功能: 返回不⼩于 X 的最⼩整数
⽤法:
mysqls: select ceiling(-1.001) value
oracle: select ceil(-1.001) value from dual
4
特斯拉销量floor(-1.001)
floor(-1.001)
功能: 返回不⼤于 X 的最⼤整数值
⽤法:
mysql: select floor(-1.001) value
oracle: select floor(-1.001) value from dual
5
Max(expr)/Min(expr)
Max(expr)/Min(expr)
功能:返回 expr 的最⼩或最⼤值。MIN() 和 MAX() 可以接受⼀个字符串参数;在这
种情况下,它们将返回最⼩或最⼤的字符串传下。
⽤法:
ROACLE: select max(user_int_key) from sd_usr;
MYSQL: select max(user_int_key) from sd_usr;
6
字符串函数
ascii(str)
ascii(str)
功能:返回字符串 str 最左边的那个字符的 ASCII 码值。如果 str 是⼀个空字符串,
那么返回值为 0。如果 str 是⼀个 NULL,返回值也是 NULL.
⽤法:
mysql:select ascii('a') value
oracle:select ascii('a') value from dual
7
CHAR(N,...)
CHAR(N,...)
功能:CHAR() 以整数类型解释参数,返回这个整数所代表的 ASCII 码值给出的字符
组成的字符串。NULL 值将被忽略.
⽤法:
input只能输入0到100
mysql:select char(97) value
oracle:select chr(97) value from dual
8
REPLACE(str,from_str,to_str)
REPLACE(str,from_str,to_str)
功能: 在字符串 str 中所有出现的字符串 from_str 均被 to_str 替换,然后返回这个字符串.⽤法:
mysql: SELECT REPLACE('abcdef', 'bcd', 'ijklmn') value
oracle: SELECT Replace('abcdef', 'bcd', 'ijklmn') value from dual
9
INSTR('sdsq','s',2)
INSTR('sdsq','s')
参数个数不同
ORACLE: select INSTR('sdsq','s',2) value from dual(要求从位置2开始) MYSQL: select INSTR('sdsq','s') value(从默认的位置1开始)
10
SUBSTR('abcd',2,2)
substring('abcd',2,2)
函数名称不同:
ORACLE: select substr('abcd',2,2) value from dual
MYSQL: select substring('abcd',2,2) value
11
instr(‘abcdefg’,’ab’)
locate(‘ab’,’abcdefg’)
函数名称不同:
instr -> locate(注意:locate的⼦串和总串的位置要互换)
ORACLE: SELECT instr('abcdefg', 'ab') VALUE FROM DUAL MYSQL: SELECT locate('ab', 'abcdefg') VALUE
12
length(str)
char_length()
函数名称不同:
ORACEL: SELECT length('AAAASDF') VALUE FROM DUAL MYSQL: SELECT char_length('AAAASDF') VALUE
13
REPLACE('abcdef', 'bcd', 'ijklmn')
REPLACE('abcdef', 'bcd', 'ijklmn')
⼀样:
ORACLE: SELECT REPLACE('abcdef', 'bcd', 'ijklmn') value from dual MYSQL: SELECT REPLACE('abcdef', 'bcd', 'ijklmn') value
14
LPAD('abcd',14, '0')
LPAD('abcd',14, '0')
⼀样:
ORACLE: select LPAD('abcd',14, '0') value from dual
MYSQL: select LPAD('abcd',14, '0') value from dual
15
UPPER(iv_user_id)
UPPER(iv_user_id)
⼀样:
ORACLE: select UPPER(user_id) from sd_usr;
MYSQL: select UPPER(user_id) from sd_usr;
16
LOWER(iv_user_id)
LOWER(iv_user_id)
⼀样:
ORACLE: select LOWER(user_id) from sd_usr;
MYSQL: select LOWER(user_id) from sd_usr;
17
控制流函数
ail_address, 10)
ail_address, 10)
ail_address)
函数名称不同(根据不同的作⽤进⾏选择):
ORACLE: ail_address, ail_address, 10) value from sd_usr u (如果u.email_address=NULl,就在DB中⽤10替换其值)
MYSQL: ail_address, ail_address, 10) value from sd_usr u(如果u.email_address=NULl,显⽰结果中是10,⽽不是在DB中⽤10替换其值)
mysql语句转ail_address, ail_address) value from sd_usr u(如果u.email_address是NULL, 就显⽰1,否则就显⽰0)
18
DECODE(iv_sr_status,g_sr_status_com, ld_sys_date, NULL)
⽆,请⽤IF或CASE语句代替.
IF语句格式:(expr1,expr2,expr3)
说明:
1. decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)
input元素有哪些该函数的含义如下:
IF 条件=值1 THEN
RETURN(翻译值1)
ELSIF 条件=值2 THEN
RETURN(翻译值2)
......
ELSIF 条件=值n THEN
RETURN(翻译值n)
ELSE
RETURN(缺省值)
END IF
2. mysql If语法说明
功能: 如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2;否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在
语境⽽定。
⽤法:
mysql: SELECT IF(1>2,2,3);
19
类型转换函数405method not allowed
TO_CHAR(SQLCODE)
date_format/ time_format
函数名称不同
SQL> select to_char(sysdate,'yyyy-mm-dd') from dual;
SQL> select to_char(sysdate,'hh24-mi-ss') from dual;
mysql> select date_format(now(),'%Y-%m-%d');
mysql> select time_format(now(),'%H-%i-%S');
20
to_date(str,format)
STR_TO_DATE(str,format)
函数名称不同:
ORACLE:SELECT to_date('2009-3-6','yyyy-mm-dd') VAULE FROM DUAL MYSQL: SELECT STR_TO_DATE('2004-03-01', '%Y-%m-%d') VAULE
21
trunc(-1.002)
cast(-1.002 as SIGNED)
函数名称不同:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。