常见SQL函数需要注意的细节
版权声明:本文为博主原创文章,未经博主允许不得转载。
这是一位牛人让我们思考的问题,说实话当时真蒙了,函数虽然明白,但细化到这种程度,真的是叫不准啊,下面是几道比较典型的问题,和本人做的实验,不一定准确,而且测验的方法不只一种,请大家多多见谅,一起学习,共同进步!!!
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
知识共享~共同进步
转载请注明:
常见SQL函数需要注意的细节的更多相关文章
- SQLServer 常见SQL函数
SQL Server SQL函数 by:授客 QQ:1033553122 字符函数 日期函数 数学函数 系统函数
- SQL函数说明大全
一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描 ...
- SQL函数说明大全 (转)
一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描 ...
- sql函数(转)
一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描 ...
- SQL函数介绍
http://www.cnblogs.com/moss_tan_jun/archive/2010/08/23/1806861.html 一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用 ...
- [转] SQL函数说明大全
from http://www.cnblogs.com/moss_tan_jun/archive/2010/08/23/1806861.html 一旦成功地从表中检索出数据,就需要进一步操纵这些数据, ...
- Access、SQLServer、Oracle常见SQL语句应用区别
Access.SQLServer.Oracle常见SQL语句应用区别 关劲松 PMP 如果要兼容Access.SQL Server.Oracle三个数据库版本:我们在编写SQL语句的过程中,尽量使用一 ...
- SQLServer 常见SQL笔试题之语句操作题详解
SqlServer 常见SQL笔试题之语句操作题详解 by:授客 QQ:1033553122 测试数据库 CREATE DATABASE handWriting ON PRIMARY ( name = ...
- SQL函数小记
写一篇笔记,记录一下常见的sql函数,以备之后的查找需要. 算数函数 abs(num):绝对值函数 mod(被除数,除数):求余函数 round(num,保留小数的位数):四舍五入函数 字符串函数 c ...
随机推荐
- ORACLE 表空间使用率查询
SELECT A.TABLESPACE_NAME, A.BYTES / (1024 * 1024 * 1024 ) TOTAL, B.BYTES / (1024 * 1024 * 1024 ) USE ...
- Monkey源代码分析之事件源
上一篇文章<Monkey源代码分析之执行流程>给出了monkey执行的整个流程.让我们有一个概貌,那么往后的文章我们会尝试进一步的阐述相关的一些知识点. 这里先把整个monkey类的结构图 ...
- Jenkins+GitHub+Xcode+fir搭了一个持续集成环境
enkins+GitHub+Xcode+fir搭了一个持续集成环境 字数826 阅读5699 评论44 喜欢49 原文链接 Coding Duck 今天用Jenkins+GitHub+Xcode+fi ...
- left join,right join用法简介
方法一(推荐): select a.man_id,man_name,d.sex_name,zw_name,c.money from man as a left join zw as b on a.zw ...
- mysql 存储过程初探
使用存储过程好处在于: 1.隐藏敏感的算法,避免被正常的开发人员看到,把业务逻辑隐藏在数据库中,而非程序代码里 2.简化应用代码程序,放到数据库里肯定就对程序代码简化有好处了 3.不同的开发语言都可以 ...
- phpcms的基础知识和配置
一.设置界面 1.站点设置:相当于服务器上的站点 (1)站点修改:“关键词”和“描述”的修改,便于网络优化和搜索引擎对本网站的搜索. (2)点击站点后边的修改,模板的修改,引用自己模板 2.基本设置: ...
- LINQ分页工具
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Co ...
- Netty 源码(ChannelHandler 死磕)
精进篇:netty源码死磕5 - 揭开 ChannelHandler 的神秘面纱 目录 1. 前言 2. Handler在经典Reactor中的角色 3. Handler在Netty中的坐标位置 4 ...
- 【JavaScript专题】--- 立即执行函数表达式
一 什么是立即执行函数表达式 立即执行函数表达式,其实也可以叫初始化函数表达式,英文名:IIFE,immediately-inovked-function expression.立即执行函数表达式就是 ...
- [luogu3413]萌数
[luogu3413]萌数 luogu 考虑数位dp 怎么判断一个数是不是萌数? 只要知道其中某一位和它的前一位相等或者和前一位的前一位相等,那么它就是一个萌数 什么样的数不是萌数? 对于它的每一位都 ...