- 浏览: 193677 次
- 性别:
- 来自: 深圳
-
文章分类
最新评论
-
sun625470637:
数据库读出来的是Thu Mar 15 19:09:25 CST ...
Java自定义时间格式全接触 -
sun625470637:
数据库读出来的是Thu Mar 15 19:09:25 CST ...
Java自定义时间格式全接触 -
Breather.杨:
http://www.open-open.com/lib/vi ...
java导入导出excel操作(jxl) -
scjingying:
baiawquqf 写道 evry good!好东西呀!我晕, ...
java导入导出excel操作(jxl) -
rock1103:
中文乱码
java导出csv文件
SQLServer和Oracle是大家经常用到的数据库,在此感谢作者总结出这些常用函数以供大家参考。
数学函数
1.绝对值
S:seleCT abs(-1) value
O:select abs(-1) value from dual
2.取整(大)
S:select ceiling(-1.001) value
O:select ceil(-1.001) value from dual
3.取整(小)
S:select floor(-1.001) value
O:select floor(-1.001) value from dual
4.取整(截取)
S:select cast(-1.002 as int) value
O:select trunc(-1.002) value from dual
5.四舍五入
S:select round(1.23456,4) value 1.23460
O:select round(1.23456,4) value from dual 1.2346
6.e为底的幂
S:select Exp(1) value 2.7182818284590451
O:select Exp(1) value from dual 2.71828182
7.取e为底的对数
S:select log(2.7182818284590451) value 1
O:select ln(2.7182818284590451) value from dual; 1
8.取10为底对数
S:select log10(10) value 1
O:select log(10,10) value from dual; 1
9.取平方
S:select SQUARE(4) value 16
O:select power(4,2) value from dual 16
10.取平方根
S:select SQRT(4) value 2
O:select SQRT(4) value from dual 2
11.求任意数为底的幂
S:select power(3,4) value 81
O:select power(3,4) value from dual 81
12.取随机数
S:select rand() value
O:select sys.dbms_random.value(0,1) value from dual;
13.取符号
S:select sign(-8) value -1
O:select sign(-8) value from dual -1
14.圆周率
S:SELECT PI() value 3.1415926535897931
O:不知道
15.sin,cos,tan 参数都以弧度为单位
例如:select sin(PI()/2) value 得到1(SQLServer)
16.Asin,Acos,Atan,Atan2 返回弧度
17.弧度角度互换(SQLServer,Oracle不知道)
DEGREES:弧度-〉角度
RADIANS:角度-〉弧度
数值间比较
18. 求集合最大值
S:select max(value) value from
(select 1 value
union
select -2 value
union
select 4 value
union
select 3 value)a
O:select greatest(1,-2,4,3) value from dual
19. 求集合最小值
S:select min(value) value from
(select 1 value
union
select -2 value
union
select 4 value
union
select 3 value)a
O:select least(1,-2,4,3) value from dual
20.如何处理null值(F2中的null以10代替)
S:select F1,IsNull(F2,10) value from Tbl
O:select F1,nvl(F2,10) value from Tbl
21.求字符序号
S:select ascii('a') value
O:select ascii('a') value from dual
22.从序号求字符
S:select char(97) value
O:select chr(97) value from dual
23.连接
S:select '11'+'22'+'33' value
O:select CONCAT('11','22') 33 value from dual
23.子串位置 --返回3
S:select CHARINDEX('s','sdsq',2) value
O:select INSTR('sdsq','s',2) value from dual
23.模糊子串的位置 --返回2,参数去掉中间%则返回7
S:select patindex('%d%q%','sdsfasdqe') value
O:oracle没发现,但是instr可以通过第四个参数控制出现次数
select INSTR('sdsfasdqe','sd',1,2) value from dual 返回6
24.求子串
S:select substring('abcd',2,2) value
O:select substr('abcd',2,2) value from dual
25.子串代替 返回aijklmnef
S:SELECT STUFF('abcdef', 2, 3, 'ijklmn') value
O:SELECT Replace('abcdef', 'bcd', 'ijklmn') value from dual
26.子串全部替换
S:没发现
O:select Translate('fasdbfasegas','fa','我' ) value from dual
27.长度
S:len,datalength
O:length
28.大小写转换 lower,upper
29.单词首字母大写
S:没发现
O:select INITCAP('abcd dsaf df') value from dual
30.左补空格(LPAD的第一个参数为空格则同space函数)
S:select space(10)+'abcd' value
O:select LPAD('abcd',14) value from dual
31.右补空格(RPAD的第一个参数为空格则同space函数)
S:select 'abcd'+space(10) value
O:select RPAD('abcd',14) value from dual
32.删除空格
S:ltrim,rtrim
O:ltrim,rtrim,trim
33. 重复字符串
S:select REPLICATE('abcd',2) value
O:没发现
34.发音相似性比较(这两个单词返回值一样,发音相同)
S:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe')
O:SELECT SOUNDEX ('Smith'), SOUNDEX ('Smythe') from dual
SQLServer中用SELECT DIFFERENCE('Smithers', 'Smythers') 比较soundex的差
返回0-4,4为同音,1最高
日期函数
35.系统时间
S:select getdate() value
O:select sysdate value from dual
36.前后几日
直接与整数相加减
37.求日期
S:select convert(char(10),getdate(),20) value
O:select trunc(sysdate) value from dual
select to_char(sysdate,'yyyy-mm-dd') value from dual
38.求时间
S:select convert(char(8),getdate(),108) value
O:select to_char(sysdate,'hh24:mm:ss') value from dual
39.取日期时间的其他部分
S:DATEPART 和 DATENAME 函数 (第一个参数决定)
O:to_char函数 第二个参数决定
参数---------------------------------下表需要补充
year yy, yyyy
quarter qq, q (季度)
month mm, m (m O无效)
dayofyear dy, y (O表星期)
day dd, d (d O无效)
week wk, ww (wk O无效)
weekday dw (O不清楚)
Hour hh,hh12,hh24 (hh12,hh24 S无效)
minute mi, n (n O无效)
second ss, s (s O无效)
millisecond ms (O无效)
----------------------------------------------
40.当月最后一天
S:不知道
O:select LAST_DAY(sysdate) value from dual
41.本星期的某一天(比如星期日)
S:不知道
O:SELECT Next_day(sysdate,7) vaule FROM DUAL;
42.字符串转时间
S:可以直接转或者select cast('2004-09-08'as datetime) value
O:SELECT To_date('2004-01-05 22:09:38','yyyy-mm-dd hh24-mi-ss') vaule FROM DUAL;
43.求两日期某一部分的差(比如秒)
S:select datediff(ss,getdate(),getdate()+12.3) value
O:直接用两个日期相减(比如d1-d2=12.3)
SELECT (d1-d2)*24*60*60 vaule FROM DUAL;
44.根据差值求新的日期(比如分钟)
S:select dateadd(mi,8,getdate()) value
O:SELECT sysdate+8/60/24 vaule FROM DUAL;
45.求不同时区时间
S:不知道
O:SELECT New_time(sysdate,'ydt','gmt' ) vaule FROM DUAL;
-----时区参数,北京在东8区应该是Ydt-------
AST ADT 大西洋标准时间
BST BDT 白令海标准时间
CST CDT 中部标准时间
EST EDT 东部标准时间
GMT 格林尼治标准时间
HST HDT 阿拉斯加?夏威夷标准时间
MST MDT 山区标准时间
NST 纽芬兰标准时间
PST PDT 太平洋标准时间
YST YDT YUKON标准时间
发表评论
-
Oracle的锁机制归纳总结
2008-12-13 11:29 7604锁是防止在两个 ... -
oracle数据库锁的概念
2008-12-13 10:47 4683为了确保并发用户在存取同一数据库对象时的正确性(即无丢失修改、 ... -
oracle日期和时间
2008-10-21 17:38 1874Oracle 提供了三个用于存储日期/时间值的数据类型: 表示 ... -
oracle分页
2008-10-21 16:09 882Oracle的rownum字段是个比较奇怪的字段。拿一张有26 ... -
oracle中时间字段查询
2008-06-22 15:56 2169一.TimeStamp类型字段: select ca ... -
采用过程实现数据库约束完整性
2008-06-22 15:38 1081约束的完整性,是数据库所具有的一大特性,但在最近的 ... -
数据库批处理的几种方法
2008-06-16 21:18 3685首先,要关闭数据库连接的自动提交。否则就不叫批处理了。 co ... -
oracle中自增长列的生成方案
2008-05-18 23:38 1346最近遇到一个 ... -
oracle-序列(SEQUENCE)
2008-04-29 12:50 8649在oracle中sequence就是所谓的序列号, ... -
oracle 存储过程的基本语法
2008-04-28 17:54 13121.基本结构 CREATE OR REPLACE PROC ... -
Oracle SQL语句优化技术分析
2008-03-31 13:58 860操作符优化 IN 操作符 用IN写出来的SQL的优点是比较容易 ... -
Oracle中一个日期查找的误区
2008-03-31 11:50 1100经常要在数据中检索近一个月来发生的数据,所以采用如下语句 ... -
Oracle快速删除重复的记录
2008-03-31 11:33 988做项目的时候,一位同事导数据的时候,不小心把一个表中的数据全都 ... -
“数字公交”项目中的oracle开发技巧
2008-03-31 10:41 958参与进"数字公交"项目已经有一个多月了,我 ... -
Oracle的25条基本知识
2008-03-31 10:33 1164Oracle 基本知识轻松学: 1.一个表空间只能属于一个数据 ... -
深入浅出:数据库设计模式范例
2008-03-31 10:22 1374关系数据库设计之时是 ... -
简单提高ORACLE数据库的查询统计速度
2008-03-31 10:19 1192大型数据库系统中往往要用到查询统计,但是对于数据量大的系统,用 ... -
Oracle数据库系统使用经验六则
2008-03-30 11:11 8521.having 子句的用法 having ... -
Oracle数据库字段上建立索引
2008-03-30 11:08 1097当where子句对某一列使用函数时,除非利用这个简单的技术强制 ... -
Oracle中实现搜索分页查询
2008-03-28 12:32 1149在构建自定义搜索引擎时,开发人员常遇到的一个问题是实现某种类型 ...
相关推荐
### SQLServer和Oracle常用函数对比 本文将详细探讨在SQLServer与Oracle数据库系统中常用的数学函数及字符串处理函数之间的差异。对于数据分析师、数据库管理员以及软件开发者而言,掌握这两种数据库管理系统之间的...
### SQLServer和Oracle常用函数对比 本文将对SQLServer与Oracle数据库系统中常用的数学与字符串处理函数进行详细的对比分析。通过具体的示例和解释,帮助读者更好地理解两种数据库管理系统在处理相似需求时的不同...
本文将深入探讨SQL Server和Oracle中的常用函数,并进行详细的对比分析。 ### 一、数值处理函数 #### 1. 绝对值 - **SQL Server**: 使用`ABS`函数。 - 示例:`SELECT ABS(-1)` - **Oracle**: 同样使用`ABS`函数。...
通过以上对比,我们可以看出SQLServer和Oracle在提供基本数学函数和字符串处理功能方面非常相似,但具体语法上存在细微差别。对于开发人员来说,在选择使用这些函数时需要根据具体的数据库环境来决定使用哪种语法。...
本文将基于给定文件信息,深入探讨和对比SQLServer与Oracle中的一些常用函数,这些函数涵盖了数学运算、数值处理、字符串操作等多个方面,对于数据库开发者和管理员而言,掌握这些函数的使用方法是提升工作效率的...
本篇文章将深入探讨SQL Server与Oracle中的一些常见函数,并进行对比分析,旨在帮助数据库管理员和开发人员更好地理解和应用这些功能。 1. **字符串处理函数**: - SQL Server中的`LEN()`函数用于计算字符串的长度...
在数据库管理领域,SQL Server和Oracle都是广泛应用的关系型数据库管理系统,它们都提供了丰富的函数来处理各种数据操作。本文主要探讨的是这两个系统中常用的数学函数的区别。 1. 绝对值: 在SQL Server中,获取一...
2. 取整(向上取整):SQL Server中的`CEILING()`函数和Oracle中的`CEIL()`函数都能将数值向上取整。 3. 取整(向下取整):SQL Server的`FLOOR()`函数和Oracle的`FLOOR()`函数则会将数值向下取整。 4. 截取整数...
以上对比展示了 SQL Server 和 Oracle 在常用数学函数和字符串处理函数方面的相似之处和差异。尽管这些函数的名称和语法可能有所不同,但它们的基本功能和用途是相同的。理解这些异同可以帮助开发人员更灵活地在不同...