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

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

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. Java 异常介绍

    Java标准库内建了一些通用的异常,这些类以 Throwable 为顶层父类.Throwable又派生出 Error 类和 Exception 类. 错误:Error类以及他的子类的实例,代表了JVM ...

  2. Unable to VNC onto Centos server remotely

    用的好好的vncserver 突然遇到这个错误: [vnc@localhost ~]$ sudo systemctl status vncserver@:1.service -l● vncserver ...

  3. Linux64位程序移植

    1 概述 Linux下的程序大多充当服务器的角色,在这种情况下,随着负载量和功能的增加,服务器所使用内存必然也随之增加,然而32位系统固有的4GB虚拟地址空间限制,在如今已是非常突出的问题了:另一个需 ...

  4. iOS开发---业务逻辑

    iOS开发---业务逻辑   1. 业务逻辑 iOS的app开发的最终目的是要让用户使用, 用户使用app完成自己的事就是业务逻辑, 业务逻辑的是最显眼开发工作.但是业务逻辑对于开发任务来说, 只是露 ...

  5. [Sdoi2013]随机数生成器(BSGS)

    #include<cstdio> #include<cstring> #include<cmath> #include<iostream> #inclu ...

  6. SQLServer将一个表内指定列的所有值插入另一个表

    insert into records_resolve_bak(resolve_save_addr,resolve_time,resolve_status) select  resolve_save_ ...

  7. CentOS查看和修改MySQL字符集

    通过以下命令查看了MySQL的字符集 连接上mysql服务,输入以下命令 mysql>show variables like 'character_set%'; 显示如下: 为了让MySQL支持 ...

  8. ABAP 发邮件(三)

    [转自http://blog.sina.com.cn/s/blog_7c7b16000101bnxk.html]SAP ABAP 发邮件方法三(OO) *&------------------ ...

  9. 数据库存储I/O类型分析与配置

    存储设备作为数据的容器,为应用提供数据存取服务,而存储系统将数据展现给不同的应用后,应用程序对数据访问不尽相同.简要来说,就是读和写,更加细分的话是以不同的传输单元(I/O大小)进行顺序和随机类型的读 ...

  10. linux 基础-变量,shell基本语法

    变量 定义变量 your_name="runoob.com" #变量名和等号之间不能有空格 使用变量 your_name="qinjx" echo $your_ ...