Microsoft SQL 中调用函数DATEPART语法为: DATEPART(datetype, date_expression).函数参数
datetype 为month, day, week, day of week 等,而第二个参数为包含日期类型的字段或者一个真实
的日期值,而mysql中的DAYNAME函数就是直接指定了当前日期为星期几,oracle中的TO_CHAR可以从日
期中拿到所需要的子域,日期,小时,分钟等。
3,时间间隔,在一些应用中需要知道两个时间间隔多远
Microsoft SQL Server
Select DATEDIFF(dd, '1/1/01', GETDATE())
GO
MySQL
Select FROM_DAYS(TO_DAYS(CURDATE()) -
TO_DAYS('2001-11-25'));
oracle
Select TO_DATE('25-Nov-2000','dd-mon-yyyy') -
TO_DATE('25-Aug-1969','dd-mon-yyyy')
FROM dual;
PostgreSQL
Select AGE(CURRENT_DATE, '25-Aug-1969');
测量不同时间的间隔,不同的数据库之间函数语法有很大的不同。
4,日期时间格式化
Microsoft SQL Server
Select CONVERT(VARCHAR(11), GETDATE(), 102)
GO
MySQL
Select DATE_FORMAT( \"2001-11-25\", \"%M %e, %Y\");
oracle
Select TO_CHAR(SYSDATE,'dd-Mon-yyyy hh:mi:ss PM')
FROM dual;
PostgreSQL
Select TO_CHAR (timestamp(CURRENT_DATE),'dd-Mon-yyyy hh:mi:ss PM');
二,字符串操作
1,字符串中包含字符
Microsoft SQL Server
Select CHARINDEX('eat', 'great')
GO
MySQL
Select POSITION('eat' IN 'great');
oracle
Select INSTR('Great','eat') FROM dual;
PostgreSQL
Select POSITION('eat' IN 'great');
通过上面的这些函数可以确定字符串在另一个字符串中的位置(及另一个字符串包含这个字符串的位置)。
2,字符串去掉空格
Microsoft SQL Server
Select LTRIM(' sql_in_a_nutshell'),
Select RTRIM('sql_in_a_nutshell '),
Select LTRIM(RTRIM(' sql_in_a_nutshell ')
GO
MySQL
Select LTRIM(' sql_in_a_nutshell'),
Select RTRIM('sql_in_a_nutshell '),
Select TRIM(' sql_in_a_nutshell '),
Select TRIM(BOTH FROM ' sql_in_a_nutshell ');
oracle
Select LTRIM(' sql_in_a_nutshell'),
Select RTRIM('sql_in_a_nutshell '),
TRIM(' sql_in_a_nutshell ')
FROM dual;
PostgreSQL
Select TRIM(LEADING FROM ' sql_in_a_nutshell'),
TRIM(TRAILING FROM 'sql_in_a_nutshell '),
TRIM(BOTH FROM ' sql_in_a_nutshell ');
3,上面清除空格相反的操作,添加空格
Microsoft SQL Server
Not supported
MySQL
Select LPAD('sql_in_a_nutshell', 20, ' '),
RPAD('sql_in_a_nutshell', 20, ' ');
oracle
Select LPAD(('sql_in_a_nutshell', 20, ' '),
RPAD(('sql_in_a_nutshell', 20, ' ')
FROM dual;
PostgreSQL
Select LPAD('sql_in_a_nutshell', 20, ' '),
RPAD('sql_in_a_nutshell', 20, ' ');
上面支持该操作的数据库的函数都相同,并且都包括从左和右添加空格的方法。
4,字符串替换
Microsoft SQL Server [returns 'wabbit_hunting_season']
Select STUFF('wabbit_season', 7, 1, '_hunting_')
GO
MySQL [returns 'wabbit_hunting_season']
Select
REPLACE('wabbit_season','it_','it_hunting_');
oracle [returns 'wabbit_hunting_season']
Select
REPLACE('wabbit_season','it_','it_hunting_')
FROM dual;
PostgreSQL
Select TRANSLATE('wabbit_season','it_','it_hunting_');
Select replace('wabbit_season','it_','it_hunting_');
5,字符串截取
Microsoft SQL Server
Select SUBSTRING('wabbit_duck_season', 7, 11)
GO
MySQL
Select
SUBSTRING('wabbit_duck_season', 7, 11);
oracle
Select SUBSTR('wabbit_duck_season', 7, 11)
FROM dual;
PostgreSQL
Select SUBSTR('wabbit_duck_season', 7, 11);
三,条件判断
1,条件判断
Microsoft SQL Server
Select CASE
WHEN foo = 'hi' THEN 'there'
WHEN foo = 'good' THEN 'bye'
ELSE 'default'
END
FROM t2
GO
MySQL
select if(('11'='11'),'1','2')
select if(2>1,'1','2')
oracle
Select DECODE
(payments_info,'CR','Credit','DB','Debit', null)
FROM dual;
PostgreSQL
Select CASE
WHEN foo = 'hi' THEN 'there'
WHEN foo = 'good' THEN 'bye'
ELSE 'default'
END
FROM t2;
上面的函数我们就不多作解释了,很容易理解,我们来说一下mysql的if()函数,如果第一个参数为
true那么返回地二个参数,否则返回第三个参数。
2,判断空函数
Microsoft SQL Server
Select ISNULL(foo, 'Value is Null')
GO
MySQL
select ifnull(122,'aaa')
oracle
Select NVL(foo,'Value is Null')
FROM dual;
PostgreSQL
Select coalesce(foo,'Value is Null')
3,下面与上面的函数不同
Microsoft SQL Server [returns NULL when foo equates to 'Wabbits!']
Select NULLIF(foo, 'Wabbits!')
GO
MySQL
N/A
oracle
Select DECODE(foo,'Wabbits!',NULL)
FROM dual;
PostgreSQL
Select NULLIF(foo, 'Wabbits!');
函数语法:NULLIF(expression1, expression2)
如果 expression1 等于 expression2则返回 NULL,如果expression1的值为null,也返回NULL
相关推荐
MSSQL DB2 ORACAL三种数据库常用函数对比大全,对比以上的数据库,查询的时候很有用。熟悉三种数据库的函数。采用excel的表格的方式呈现。
1. **Oracle数据库** - **历史与发展**:Oracle公司自1977年成立以来,一直致力于数据库技术的研发。1984年,Oracle将关系数据库引入桌面系统,并在后续版本中引入分布式数据库和客户/服务器结构。Oracle 6实现了行...
### SQLServer和Oracle常用函数对比 本文将对SQLServer与Oracle数据库系统中常用的数学与字符串处理函数进行详细的对比分析。通过具体的示例和解释,帮助读者更好地理解两种数据库管理系统在处理相似需求时的不同...
### SQLServer与Oracle常用函数对比分析 在数据库领域,SQLServer和Oracle是两种非常流行的数据库管理系统,它们各自拥有一套丰富的内置函数来帮助用户高效地完成数据查询、处理任务。本文将详细介绍这两种数据库...
### SQLServer和Oracle常用函数对比 本文将详细探讨在SQLServer与Oracle数据库系统中常用的数学函数及字符串处理函数之间的差异。对于数据分析师、数据库管理员以及软件开发者而言,掌握这两种数据库管理系统之间的...
### 数学函数对比 1. **绝对值** - SQLServer中使用`ABS()`函数。 - Oracle中同样使用`ABS()`函数。 2. **向上取整** - SQLServer中使用`CEILING()`函数。 - Oracle中使用`CEIL()`函数。 3. **向下取整** - ...
在IT领域,尤其是在数据库管理与查询方面,Oracle与SQL Server作为两种主流的数据库管理系统,各自提供了丰富的内置函数来处理数据,这些函数涵盖了数学运算、字符串操作、日期时间处理等多个方面。下面,我们将深入...
下面将对比分析这两个数据库系统中的一些常见函数。 1. 绝对值:SQL Server使用`ABS()`函数,Oracle同样使用`ABS()`函数,它们都可以计算一个数的绝对值。 2. 取整(向上取整):SQL Server中的`CEILING()`函数和...
SQLServer和Oracle的常用函数对比,方便在不同数据库做数据同步时做数据转换,与sql学习。
1. **SQL Server数据库对比**:这是数据库管理员和开发人员常用的一种技术,用于识别两个数据库实例之间的结构差异,如表、视图、存储过程、触发器、用户定义函数以及权限设置等。对比可以帮助用户在迁移、备份、...
根据提供的文件信息,本文将对Oracle与SQL Server中的常用数学函数进行对比分析。这些函数包括绝对值、向上取整、向下取整、截断、四舍五入、指数计算、自然对数、以10为底的对数、平方、平方根、幂运算以及随机数和...
### SQL Server 和 Oracle 的常用函数对比 在数据库领域中,SQL Server 和 Oracle 是两种非常流行的数据库管理系统。这两种系统虽然有着不同的背景和发展历程,但都提供了丰富的功能来支持数据的存储、管理和查询。...
下面将详细对比这两者中的一些常用函数。 1. **绝对值** - SQL Server: `ABS(-1)` 返回-1的绝对值,即1。 - Oracle: `ABS(-1)` 与SQL Server相同,同样返回1。 2. **取整(大)** - SQL Server: `CEILING(-1....