常见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

知识共享~共同进步

转载请注明:

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

时间: 2024-11-04 13:59:43

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

SQL函数说明大全

一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描述. 函数类别 作用 聚合函数 执行的操作是将多个值合并为一个值.例如 COUNT.SUM.MIN 和 MAX. 配置函数 是一种标量函数,可返回有关配置设置的信息. 转换函数 将值从一种数据类型转换为另一种. 加密函数 支持加密.解密.数字签名和数字签名验证. 游标函数 返回有关游标状态的信息.

MySQL · 性能优化 · MySQL常见SQL错误用法

前言 MySQL在2016年仍然保持强劲的数据库流行度增长趋势.越来越多的客户将自己的应用建立在MySQL数据库之上,甚至是从Oracle迁移到MySQL上来.但也存在部分客户在使用MySQL数据库的过程中遇到一些比如响应时间慢,CPU打满等情况.阿里云RDS专家服务团队帮助云上客户解决过很多紧急问题.现将<ApsaraDB专家诊断报告>中出现的部分常见SQL问题总结如下,供大家参考. 常见SQL错误用法 1. LIMIT 语句 分页查询是最常用的场景之一,但也通常也是最容易出问题的地方.比如

SQL中if exists用法细节

用if exists建表[转] 1 判断数据库是否存在 Sql代码 if exists (select * from sys.databases where name = ’数据库名’) drop database [数据库名]  if exists (select * from sys.databases where name = ’数据库名’) drop database [数据库名] 2 判断表是否存在 Sql代码 if exists (select * from sysobjects w

Oracle数据类型,DDL、DML、DCL、TCL语言,SQL操作符,SQL函数

SQL查询与SQL函数 本章目标 了解Oracle数据类型  了解数据定义语言和数据操纵语言  了解事务控制语言和数据控制语言  掌握SQL操作符和SQL函数  SQL(structured query language)--结构化查询语言   通过SQL可以实现与Oracle服务器的通信   SQL是数据库语言,Oracle使用该语言存储和检索信息       表是主要的数据库对象,用于存储数据 用户  --------------------发送SQL语句查询----------------

Oracle 11g 的PL/SQL函数结果缓存

模仿Oracle性能诊断艺术中的例子做了两个试验,书上说如果不用RELIES_ON,则函数依赖的对象发生的变更操作就不会导致结果缓存的失效操作(result_cache RELIES_ON(test1,test2)),试验证明不对,函数f1()并没有使用RELIES_ON,但表上的变化影响到了函数. C:\Documents and Settings\guogang>sqlplus gg_test/[email protected]_gg SQL*Plus: Release 10.2.0.1.0

Oracle之SQL函数

1.SQL函数(1)字符函数:主要是操纵字符串(2)数字函数:主要是操纵数字类型的数值(3)转换函数:这些函数将数据从一种数据类型转换为另一种数据类型(4)日期函数:处理日期和时间(5)正则表达式函数:这些函数使用正则表达式搜索数据2.字符函数 (1)CONCAT(m,n) 将m和n连接起来,并返回连接后的字符串 (2)INITCAP(n) 将n中的第一个字母转换成大写 (3)INSTR(x,y,m,n) 在x中查找字符串y出现的位置.其中m,n是可选项,m代表从字符串x的第m个位置开始查找.n

SQL函数

1.内建SQL函数的[语法]: select  function(列)  from  表 [自带函数]: 1.avg函数:返回数值的平均值.null值不包括. select  avg(列名)  from  表名 2.count函数:返回匹配指定条件得行数  count(列名):返回指定列的值的数目(null不计入) select  count(列名) from  表名 count(*):返回表中的记录数 count(distinct  列名):返回指定列的不同值的数目 3.first函数:返回指

计算地球上两个坐标点(经度,纬度)之间距离sql函数

go --计算地球上两个坐标点(经度,纬度)之间距离sql函数 --作者:lordbaby --整理:www.aspbc.com CREATE FUNCTION [dbo].[fnGetDistance](@LatBegin REAL, @LngBegin REAL, @LatEnd REAL, @LngEnd REAL) RETURNS FLOAT AS BEGIN --距离(千米) DECLARE @Distance REAL DECLARE @EARTH_RADIUS REAL SET @

常见SQL Server导入导出数据的几个工具

摘自:http://www.cnblogs.com/chenxizhang/archive/2011/06/09/2076542.html 在我们的日常工作中,与数据库打交道的机会越来越多.这一篇文章我整理一下常见的SQL Server导入导出数据的几个工具 1. 数据导入导出向导 这是一个可视化的工具,我放在首位,是由于它可以极大灵活地满足导入导出功能,而且是所见即所得的,易于使用. 启动数据导入导出向导的方式有好多种,我自己习惯直接通过如下的命令启动(开始=>运行) dtswizard(顾名