版权声明:本文为博主原创文章,未经博主允许不得转载。

这是一位牛人让我们思考的问题,说实话当时真蒙了,函数虽然明白,但细化到这种程度,真的是叫不准啊,下面是几道比较典型的问题,和本人做的实验,不一定准确,而且测验的方法不只一种,请大家多多见谅,一起学习,共同进步!!!

1.在数字前如何补零

SQL> select lpad('123',10,'0') from dual;

LPAD('123'

----------

0000000123

SQL> select lpad(123,10,0) from dual;

LPAD(123,1

----------

0000000123

SQL> select lpad('123',10,'0') from dual;

LPAD('123'

----------

0000000123

2.如果用trim删除空格会不会同时删除掉字符串末尾的回车或者换行符

 

方法:这里面用到了chr函数。Chr函数功能:返回以数值表达式值为编码的字符。说明:函数返回值类型为string,其数值表达式取值范围为0~255.

Chr(10)代表回车

Chr(13)代表换行

Chr(32)代表空格

SQL> select length('Hello'||chr(10)) from dual;

LENGTH('HELLO'||CHR(10))

------------------------

6

SQL> select length(trim('Hello'||chr(10))) from dual;

LENGTH(TRIM('HELLO'||CHR(10)))

------------------------------

6

SQL> select length('Hello'||chr(32)) from dual;

LENGTH('HELLO'||CHR(32))

------------------------

6

SQL> select length(trim('Hello'||chr(32))) from dual;

LENGTH(TRIM('HELLO'||CHR(32)))

------------------------------

5

SQL> select length('Hello'||chr(13)) from dual;

LENGTH('HELLO'||CHR(13))

------------------------

6

SQL> select length(trim('Hello'||chr(13))) from dual;

LENGTH(TRIM('HELLO'||CHR(13)))

------------------------------

6

结论:由上面实验可以得出空格去除不了回车和换行符。

 

3.日期函数months_between的里面的两个值如果左边的值大于右边的值会是什么结果?

查阅了下官方文档,描述如下:

Syntax

Purpose

MONTHS_BETWEEN returns number of months between datesdate1 anddate2. The month and the last day of the month are defined by the parameterNLS_CALENDAR.If date1 is later thandate2, then the result is positive. Ifdate1 is earlier thandate2, then the result is negative. Ifdate1 anddate2 are either the same days of the month or both last days of months, then the result is always an integer. Otherwise Oracle Database calculates the fractional portion of the result based on a 31-day month and considers the difference in time componentsdate1 anddate2.

通过黄色部门文字描述,可以知道如果右边(date2)大于左边(date1)返回的number是负值。

实验:

SQL> select months_between

2  (to_date('02-02-2012','mm-dd-yyyy'),

3  to_date('01-01-2012','mm-dd-yyyy')) "Months"

4  from dual;

Months

----------

1.03225806

SQL> select months_between

2  (to_date('2012-01-01','yyyy-mm-dd'),

3  to_date('2012-02-02','yyyy-mm-dd')) "Months"

4  from dual;

Months

----------

-1.0322581

结论:如果date1小于date2值为负数

 

4.case…when函数如果取出的列值有Null的话该怎么判断?

SQL> select a,

2  case nvl(b,4) when 1 then 123

3  when 2 then 123

4  when 3 then 123

5  when 4 then 888

6  when 5 then 123

7  end as b

8  from t;

A          B

---------- ----------

1        123

2        123

3        123

4        888

5        123

总结:我暂时能想到的方法就是用nvl函数转换成可见的数值或字符,我也默认不处理null得到的结果也为空,比如我不指定when 4,这样第4条也就为null了。

5.还有个就是与Null运算得出的结果也为空值。

SQL> select 5*null from dual;

5*NULL

elvis

2012.12.23

知识共享~共同进步

转载请注明:

http://blog.csdn.net/elvis_dataguru/article/details/8393947

常见SQL函数需要注意的细节的更多相关文章

  1. SQLServer 常见SQL函数

    SQL Server SQL函数 by:授客 QQ:1033553122 字符函数 日期函数 数学函数 系统函数

  2. SQL函数说明大全

    一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描 ...

  3. SQL函数说明大全 (转)

    一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描 ...

  4. sql函数(转)

    一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描 ...

  5. SQL函数介绍

    http://www.cnblogs.com/moss_tan_jun/archive/2010/08/23/1806861.html 一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用 ...

  6. [转] SQL函数说明大全

    from http://www.cnblogs.com/moss_tan_jun/archive/2010/08/23/1806861.html 一旦成功地从表中检索出数据,就需要进一步操纵这些数据, ...

  7. Access、SQLServer、Oracle常见SQL语句应用区别

    Access.SQLServer.Oracle常见SQL语句应用区别 关劲松 PMP 如果要兼容Access.SQL Server.Oracle三个数据库版本:我们在编写SQL语句的过程中,尽量使用一 ...

  8. SQLServer 常见SQL笔试题之语句操作题详解

    SqlServer 常见SQL笔试题之语句操作题详解 by:授客 QQ:1033553122 测试数据库 CREATE DATABASE handWriting ON PRIMARY ( name = ...

  9. SQL函数小记

    写一篇笔记,记录一下常见的sql函数,以备之后的查找需要. 算数函数 abs(num):绝对值函数 mod(被除数,除数):求余函数 round(num,保留小数的位数):四舍五入函数 字符串函数 c ...

随机推荐

  1. html中keydown事件

    实现在输入框按回车按钮进行查询的功能: 1.<input type="text" id="inputChannel" onkeydown="ke ...

  2. IIS中使用ASP.NET MVC的经验总结

    在这篇文章中我们学习在不同版本的IIS中使用ASP.NET MVC和URL Routing.我们学习针对IIS7.0.IIS6.0和更早版本的IIS的处理策略. ASP.NET MVC框架依赖于URL ...

  3. 8168开发之---1g内存换成512M的内存映射配置

    最近在帮新来同事调式内存分配,起初是将config.bld 中的内存在标配的基础上减少sr1,和tiler 将dsp从9m增加到16m,然后编译通过, 可是在加载的时候卡住了,init.sh 过,lo ...

  4. 怎样去掉a标签的蓝框

    直接上代码 *{-webkit-tap-highlight-color:rgba(255,0,0,0);} 我是直接给每一个都加了这个属性   其实没有必要 因为 只有a 标签 input 标签 和t ...

  5. Socket网络编程TCP、UDP演示样例

    Socket网络编程: 1) OSI(了解): 国际标准化组织ISO(International Orgnization for Standardization)指定了网络通信的模型:开放系统互联(O ...

  6. centos7.0 关闭防火墙

    1.关闭firewall:systemctl stop firewalld.service #停止firewallsystemctl disable firewalld.service #禁止fire ...

  7. SecureCRT的Home+End+Del键映射

    在securecrt界面:工具 → 键映射编辑器,在弹出的键盘中: 1.点击“home”,会弹出一个窗口,在“发送字符串”中输入:\033[1~ 2.点击“end”,会弹出一个窗口,在“发送字符串”中 ...

  8. iOS 多线程(队列、任务、串行、并行、同步、异步)

  9. 经典的css reset代码 (reset.css)

    <style> html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, ...

  10. VS2015增量编译,加快编译速度

    起因:之前工程设置的好好的, 改动一个文件,必定是只编译该文件相关的.然而最近就是无论是否改动文件,都会有部分文件重新编译. 解决流程:查看增量编译的设置1.1 因为工程是在Debug模式下,so清空 ...