Vous êtes sur la page 1sur 34

Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Uso de Funciones de Una Sola Fila para


Personalizar la Salida

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.
Objetivos
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Al finalizar esta leccin, debera estar capacitado para lo


siguiente:
Describir los diferentes tipos de funciones disponibles en
SQL
Utilizar caracteres, nmeros y funciones de fecha en
sentencias SELECT

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Objetivos
Las funciones hacen ms potente el bloque de consultas bsico y se utilizan para manipular los
valores de datos. Las primeras dos lecciones de este curso analizan las funciones. Se centra en
funciones de fecha, de carcter de una fila y de nmero.

Oracle Database: Conceptos Fundamentales de SQL I 3-2


Agenda
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funciones SQL de una sola fila


Funciones de carcter
Funciones de nmero
Trabajo con fechas
Funciones de fecha

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Oracle Database: Conceptos Fundamentales de SQL I 3-3


Funciones SQL
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Entrada Salida

Funcin

arg 1 La funcin realiza la


accin
arg 2
Resultado
valor

arg n

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Funciones SQL
Las funciones son una caracterstica muy potente de SQL. Se puede utilizar para realizar las
siguientes acciones:
Realizar clculos en los datos
Modificar elementos de datos individuales
Manipular la salida para grupos de filas
Formatear fechas y nmeros para su visualizacin
Convertir tipos de dato de columna
Algunas veces, las funciones SQL toman argumentos y siempre devuelven un valor.
Nota: si desea saber si una funcin es compatible con SQL:2003, consulte la seccin sobre
compatibilidad con SQL:2003 de la gua Oracle Database SQL Language Reference (Referencia
sobre Lenguaje SQL de Oracle Database) para la base de datos 10g u 11g.

Oracle Database: Conceptos Fundamentales de SQL I 3-4


Dos Tipos de Funciones SQL
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funciones

Una sola fila Varias filas


funciones funciones

Devuelve un resultado Devuelve un resultado


por fila por juego de filas

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Dos Tipos de Funciones SQL


Hay dos tipos de grupos de funciones:
Funciones de una sola fila
Funciones de varias filas
Funciones de Una Sola Fila
Estas funciones funcionan slo en filas nicas y devuelven un resultado por fila. Existen distintos
tipos de funciones de una sola fila. En esta leccin se abordan los siguientes temas:
Carcter
Nmero
Fecha
Conversin
General
Funciones de Varias Filas
Las funciones pueden manipular grupos de filas para proporcionar un resultado por grupo de filas.
Estas funciones tambin se conocen como funciones de grupo (se tratan en la leccin titulada
Informes de Datos Agregados con Funciones de Grupo).
Nota: para obtener ms informacin y una lista completa de las funciones disponibles y su sintaxis,
consulte la seccin sobre funciones en Oracle Database SQL Language Reference (Referencia sobre
Lenguaje SQL de Oracle Database) para la base de datos 10g u 11g.

Oracle Database: Conceptos Fundamentales de SQL I 3-5


Funciones de Una Sola Fila
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funciones de una sola fila:


Manipular elementos de datos
Aceptar argumentos y devolver un valor
Actuar en cada fila devuelta
Devolver un resultado por fila
Posibilidad de modificar el tipo de dato
Posibilidad de anidamiento
Aceptar argumentos que pueden ser una columna o una
expresin
function_name [(arg1, arg2,...)]

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Funciones de Una Sola Fila


Las funciones de una sola fila se utilizan para manipular elementos de datos. Aceptan uno o varios
argumentos y devuelven un valor para cada fila devuelta por la consulta. Un argumento puede ser
uno de los siguientes elementos:
Constante proporcionada por el usuario
Valor de variable
Nombre de columna
Expresiones
Las caractersticas de las funciones de una sola fila son:
Actuar en cada fila devuelta en la consulta
Devolver un resultado por fila
Posibilidad de devolver un valor de datos de un tipo diferente al que se hace referencia
Posibilidad de esperar uno o ms argumentos
Se pueden utilizar en clusulas SELECT, WHERE y ORDER BY; posibilidad de anidamiento
En la sintaxis:
function_name Es el nombre de la funcin.
arg1, arg2 Es cualquier argumento que utilizar la funcin. Pueden estar
representados por un nombre de columna o expresin.

Oracle Database: Conceptos Fundamentales de SQL I 3-6


Funciones de Una Sola Fila
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Carcter

Una sola fila


General Nmero
funciones

Conversin Date

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Funciones de Una Sola Fila (continuacin)


Esta leccin trata las siguientes funciones de una sola fila:
Funciones de carcter: ceptan la entrada de caracteres y pueden devolver valores de nmero
y de carcter.
Funciones numricas: aceptan valores de entrada y devuelven valores numricos.
Funciones de fecha: operan en valores del tipo de dato DATE. (Todas las funciones de fecha
devuelven un valor de tipo de dato DATE excepto la funcin MONTHS_BETWEEN, que devuelve
un nmero.)
Las siguientes funciones de una sola fila se tratan en las lecciones tituladas Uso de Funciones de
Conversin y Expresiones Condicionales:
Funciones de conversin: Convierten un valor de un tipo de dato a otro
Funciones generales:
- NVL
- NVL2
- NULLIF
- COALESCE
- CASE
- DECODE

Oracle Database: Conceptos Fundamentales de SQL I 3-7


Agenda
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funciones SQL de una sola fila


Funciones de carcter
Funciones de nmero
Trabajo con fechas
Funciones de fecha

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Oracle Database: Conceptos Fundamentales de SQL I 3-8


Funciones de Carcter
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Carcter
funciones

Conversin de caracteres Manipulacin de caracteres


funciones funciones

LOWER CONCAT
UPPER SUBSTR
INITCAP LENGTH
INSTR
LPAD | RPAD
TRIM
REPLACE

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Funciones de Carcter
Las funciones de carcter de una sola fila aceptan los datos de caracteres como entrada y pueden
devolver valores numricos y de carcter. Las funciones de carcter se pueden dividir en:
Funciones de conversin de caracteres
Funciones de manipulacin de caracteres
Funcin Objetivo
LOWER(column|expression) Convertir valores de carcter alfabtico a minsculas.
UPPER(column|expression) Convertir valores de carcter alfabtico a maysculas.
INITCAP(column|expression) Convertir valores de carcter alfabtico en maysculas; la
primera letra de cada palabra y el resto en minsculas.
CONCAT(column1|expression1, Concatenar el primer valor de carcter con el segundo valor
column2|expression2) de carcter; equivalente al operador de concatenacin (||).
SUBSTR(column|expression,m[ Devolver los caracteres especificados de un valor de carcter
,n]) que empieza por la posicin de carcter m, de una longitud
de n caracteres (si m es negativo, el recuento empieza desde
el final del valor de carcter. Si se omite n, se devolvern
todos los caracteres del final de la cadena).
Nota: las funciones tratadas en esta leccin son slo algunas de las funciones disponibles.

Oracle Database: Conceptos Fundamentales de SQL I 3-9


Funciones de Caracteres (continuacin)
Funcin Objetivo
LENGTH(column|expression) Devolver el nmero de caracteres en la expression.
INSTR(column|expression, Devolver la posicin numrica de una cadena
string, [,m], [n] )
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

denominada.
Opcionalmente, puede proporcionar una posicin m
para iniciar la bsqueda y el n de incidencias de la
cadena. m y n tienen un valor por defecto de 1, lo cual
significa que se inicia la bsqueda al principio y se
informa de la primera incidencia.
LPAD(column|expression, n, Devolver una expresin con relleno a la izquierda de n
'string') caracteres con una expresin de caracteres.
RPAD(column|expression, n,
Devolver una expresin con relleno a la derecha de n
'string')
caracteres con una expresin de caracteres.
TRIM(leading|trailing|both, Permite recortar los caracteres finales o de encabezado
trim_character FROM (o ambos) de una cadena de caracteres. Si
trim_source)
trim_character o trim_source es un literal de carcter,
debe incluirlo entre comillas simples.
sta es una funcin disponible en Oracle8i y versiones
posteriores.
REPLACE(text, Busca una expresin de texto para una cadena de
search_string, caracteres y, si la encuentra, sustituirla por una cadena
replacement_string)
de sustitucin especificada.

Nota: algunas de las funciones total o parcialmente compatibles con SQL:2003 son:
UPPER
LOWER
TRIM
LENGTH
SUBSTR
INSTR
Para obtener ms informacin, consulte la seccin sobre compatibilidad de Oracle con Core
SQL:2003 en Oracle Database SQL Language Reference (Referencia sobre Lenguaje SQL de
Oracle Database) para la base de datos 10g u 11g .

Oracle Database: Conceptos Fundamentales de SQL I 3-10


Funciones de Conversin de Caracteres
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Estas funciones convierten las maysculas/minsculas para


cadenas de caracteres:
Funcin Resultado
LOWER('SQL Course') sql course
UPPER('SQL Course') SQL COURSE
INITCAP('SQL Course') Sql Course

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Funciones de Conversin de Caracteres


LOWER, UPPER y INITCAP son las tres funciones de conversin de caracteres.
LOWER: convierte las cadenas de caracteres en maysculas o en maysculas/minsculas a
minsculas.
UPPER: convierte las cadenas de caracteres en minscula o en maysculas/minsculas a
maysculas.
INITCAP: convierte la primera letra de cada palabra a maysculas y el resto de las letras a
minsculas.
SELECT 'The job id for '||UPPER(last_name)||' is '
||LOWER(job_id) AS "EMPLOYEE DETAILS"
FROM employees;


Oracle Database: Conceptos Fundamentales de SQL I 3-11
Uso de Funciones de Conversin de Caracteres
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Mostrar el nmero de empleado, nombre y nmero de


departamento del empleado Higgins:
SELECT employee_id, last_name, department_id
FROM employees
WHERE last_name = 'higgins';

SELECT employee_id, last_name, department_id


FROM employees
WHERE LOWER(last_name) = 'higgins';

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Uso de Funciones de Conversin de Caracteres


El ejemplo de la diapositiva muestra el nmero de empleado, nombre y nmero de departamento del
empleado Higgins:
La clusula WHERE de la primera sentencia SQL especifica el nombre del empleado como
higgins. Debido a que todos los datos de la tabla EMPLOYEES estn almacenados correctamente,
el nombre higgins no encuentra ninguna coincidencia en la tabla y no se selecciona ninguna fila.
La clusula WHERE de la segunda sentencia SQL especifica que el nombre del empleado de la tabla
EMPLOYEES se compara con higgins, convirtiendo la columna LAST_NAME a minsculas para
poder compararla. Ya que ambos nombres no estn en minsculas, se ha encontrado una coincidencia
y se ha seleccionado una fila. La clusula WHERE se puede volver a escribir de la siguiente forma
para que produzca el mismo resultado:
...WHERE last_name = 'Higgins'
El nombre de la salida aparece tal y como se almacen en la base de datos. Para mostrar el nombre
en maysculas, utilice la funcin UPPER de la sentencia SELECT.
SELECT employee_id, UPPER(last_name), department_id
FROM employees
WHERE INITCAP(last_name) = 'Higgins';

Oracle Database: Conceptos Fundamentales de SQL I 3-12


Funciones de Manipulacin de Caracteres
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Estas funciones manipulan las cadenas de caracteres:

Funcin Resultado
CONCAT('Hello', 'World') HelloWorld
SUBSTR('HelloWorld',1,5) Hello
LENGTH('HelloWorld') 10
INSTR('HelloWorld', 'W') 6
LPAD(salary,10,'*') *****24000
RPAD(salary, 10, '*') 24000*****
REPLACE BLACK and BLUE
('JACK and JUE','J','BL')
TRIM('H' FROM 'HelloWorld') elloWorld

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Funciones de Manipulacin de Caracteres


CONCAT, SUBSTR, LENGTH, INSTR, LPAD, RPAD y TRIM son funciones de manipulacin de
caracteres que se tratan en esta leccin.
CONCAT: une los valores. (Slo se pueden utilizar dos parmetros con CONCAT).
SUBSTR: extrae una cadena de una longitud determinada
LENGTH: muestra la longitud de una cadena como un valor numrico
INSTR: obtiene la posicin numrica de un carcter denominado
LPAD: dDevuelve una expresin con relleno a la izquierda de caracteres n con una expresin de
caracteres
RPAD: devuelve una expresin con relleno a la derecha de caracteres n con una expresin de
caracteres
TRIM: recorta los caracteres finales o de encabezado (o ambos) de una cadena de caracteres (si
trim_character o trim_source es un carcter literal, debe incluirlo entre comillas
simples)
Nota: puede utilizar funciones como UPPER y LOWER con una sustitucin con ampersand. Por
ejemplo, utilice UPPER('&job_title') para que el usuario no tenga que introducir el puesto en
un formato especfico.

Oracle Database: Conceptos Fundamentales de SQL I 3-13


Uso de las Funciones de Manipulacin de
Caracteres
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

1
SELECT employee_id, CONCAT(first_name, last_name) NAME,
job_id, LENGTH (last_name), 2
INSTR(last_name, 'a') "Contains 'a'?"
FROM employees 3
WHERE SUBSTR(job_id, 4) = 'REP';

1 2 3

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Uso de las Funciones de Manipulacin de Caracteres


El ejemplo de la diapositiva muestra los nombres y apellidos de los empleados que se han unido, la
longitud del apellido del empleado y la posicin numrica de la letra a en el apellido del empleado
de todos los empleados que tienen la cadena REP incluida en el ID de trabajo que empieza en la
cuarta posicin de dicho ID.
Ejemplo:
Modifique la sentencia SQL de la diapositiva para mostrar los datos de los empleados cuyos
apellidos acaben con la letra n.
SELECT employee_id, CONCAT(first_name, last_name) NAME,
LENGTH (last_name), INSTR(last_name, 'a') "Contains 'a'?"
FROM employees
WHERE SUBSTR(last_name, -1, 1) = 'n';

Oracle Database: Conceptos Fundamentales de SQL I 3-14


Agenda
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funciones SQL de una sola fila


Funciones de carcter
Funciones de nmero
Trabajo con fechas
Funciones de fecha

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Oracle Database: Conceptos Fundamentales de SQL I 3-15


Funciones Numricas

ROUND: redondea el valor a un decimal especificado


Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

TRUNC: trunca el valor a un decimal especificado


MOD: devuelve el resto de la divisin

Funcin Resultado
ROUND(45.926, 2) 45.93
TRUNC(45.926, 2) 45.92
MOD(1600, 300) 100

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Funciones Numricas
Las funciones numricas aceptan entradas numricas y devuelven valores numricos. Esta seccin
describe algunas de las funciones numricas.
Funcin Objetivo
ROUND(column|expression, n) Redondear la columna, expresin o valor a n decimales
o, si se omite n, a ningn decimal (Si n es negativo,
se redondearn los nmeros a la izquierda del decimal.)
TRUNC(column|expression, n) Truncar la columna, expresin o valor a n decimales o,
si n se omite, el valor por defecto de n es cero
MOD(m,n) Devolver el resto de m dividido entre n

Nota: esta lista contiene slo algunas de las funciones numricas disponibles.
Para obtener ms informacin, consulte la seccin sobre funciones numricas en la gua Oracle
Database SQL Language Reference (Referencia sobre Lenguaje SQL de Oracle Database) para la
base de datos 10g u 11g.

Oracle Database: Conceptos Fundamentales de SQL I 3-16


Uso de la Funcin ROUND
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

1 2
SELECT ROUND(45.923,2), ROUND(45.923,0),
ROUND(45.923,-1) 3
FROM DUAL;

1 2 3
DUAL es una tabla pblica que puede utilizar para ver los
resultados de funciones y clculos.

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Uso de la Funcin ROUND


La funcin ROUND redondea la columna, expresin o valor a n decimales. Si falta el segundo
argumento o tiene un valor de 0, el valor se redondea a cero decimales. Si el segundo argumento
tiene un valor de 2, el valor se redondea a dos decimales. Por el contrario, si el segundo argumento es
2, el valor se redondea a dos decimales a la izquierda (redondeados a la unidad ms cercana a 100).
La funcin ROUND tambin se puede utilizar con las funciones de fecha. Ver varios ejemplos ms
adelante en esta leccin.
Tabla DUAL
El usuario SYS es el propietario de la tabla DUAL, a la que pueden acceder todos los usuarios.
Contiene una columna, DUMMY, y una fila con el valor X. La tabla DUAL es til cuando slo desea
devolver un valor una vez (por ejemplo, el valor de una constante, pseudocolumna o expresin que
no se deriva de una tabla con datos de usuario). La tabla DUAL se utiliza generalmente para obtener
una visin ms completa de la sintaxis de la clusula SELECT, porque las clusulas SELECT y
FROM son obligatorias y muchos clculos no tienen que realizar selecciones en las tablas reales.

Oracle Database: Conceptos Fundamentales de SQL I 3-17


Uso de la Funcin TRUNC
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

1 2
SELECT TRUNC(45.923,2), TRUNC(45.923),
TRUNC(45.923,-1) 3
FROM DUAL;

1 2 3

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Uso de la Funcin TRUNC


La funcin TRUNC trunca la columna, expresin o valor a n decimales.
La funcin TRUNC funciona con argumentos similares a los de la funcin ROUND. Si falta el segundo
argumento o tiene un valor de 0, el valor se trunca a cero decimales. Si el segundo argumento tiene
un valor de 2, el valor se trunca a dos decimales. Por el contrario, si el segundo argumento tiene un
valor de 2, el valor se trunca a dos decimales a la izquierda. Si el segundo argumento tiene un valor
de 1, el valor se trunca a un decimal a la izquierda.
Al igual que la funcin ROUND, la funcin TRUNC se puede utilizar con funciones de fecha.

Oracle Database: Conceptos Fundamentales de SQL I 3-18


Uso de la Funcin MOD
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Para todos los empleados con un puesto de vendedor, calcular


el resto del salario despus de dividirlo entre 5.000.

SELECT last_name, salary, MOD(salary, 5000)


FROM employees
WHERE job_id = 'SA_REP';

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Uso de la Funcin MOD


La funcin MOD obtiene el resto del primer argumento dividido entre el segundo argumento. El
ejemplo de la diapositiva calcula el resto del salario despus de dividirlo entre 5.000 de todos los
empleados cuyo ID de trabajo sea SA_REP.
Nota: la funcin MOD se suele utilizar para determinar si un valor es par o impar. La funcin MOD es
tambin la funcin hash de Oracle.

Oracle Database: Conceptos Fundamentales de SQL I 3-19


Agenda
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funciones SQL de una sola fila


Funciones de carcter
Funciones de nmero
Trabajo con fechas
Funciones de fecha

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Oracle Database: Conceptos Fundamentales de SQL I 3-20


Trabajo con Fechas
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Oracle Database almacena fechas en un formato numrico


interno: siglo, ao, mes, da, horas, minutos y segundos.
El formato de visualizacin de la fecha por defecto es
DD-MON-RR.
Permite almacenar fechas del siglo 21 en el siglo 20
especificando slo los dos ltimos dgitos del ao
De la misma forma, permite almacenar fechas del
siglo 20 en el siglo 21

SELECT last_name, hire_date


FROM employees
WHERE hire_date < '01-FEB-88';
';

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Trabajo con Fechas


Oracle Database almacena fechas en un formato numrico interno que representa el siglo, el ao, el
mes, las horas, los minutos y los segundos.
La visualizacin por defecto y el formato de entrada de cualquier fecha es DD-MON-RR. Las fechas
de Oracle vlidas son del 1 de enero de 4712 A.C. y el 31 de diciembre de 9999 D.C.
En el ejemplo de la diapositiva, la salida de la columna HIRE_DATE aparece en el formato por
defecto DD-MON-RR. Sin embargo, las fechas no se almacenan en la base de datos en este formato.
Se almacenan todos los componentes de la fecha y la hora. Por lo tanto, aunque un valor
HIRE_DATE de 17-JUN-87 aparezca como el da, mes y ao, tambin existe informacin de hora y
siglo asociada a la fecha. Los datos completos podran ser 17 de junio de 1987, 5:10:43 PM.

Oracle Database: Conceptos Fundamentales de SQL I 3-21


Formato de Fecha RR
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

AoActual
Ao Actual Fecha Especificada Formato RR Formato YY
1995 27-OCT-95 1995 1995
1995 27-OCT-17 2017 1917
2001 27-OCT-17 2017 2017
2001 27-OCT-95 1995 2095

Si el ao de dos dgitos especificado es:

049 5099
Si dos de La fecha de La fecha de
los dgitos 049 devolucin est en devolucin est en el
del ao el siglo actual siglo anterior al actual
actual son: La fecha de devolucin La fecha de
5099 est en el siglo devolucin est en
posterior al actual el siglo actual

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Formato de Fecha RR
El formato de fecha RR es similar al elemento YY, pero puede utilizarlo para especificar siglos
diferentes. Utilice el elemento de formato de fecha RR en lugar de YY para que el siglo del valor de
retorno vare segn el ao de dos dgitos especificado y los ltimos dos dgitos del ao actual. La
tabla de la diapositiva resume el comportamiento del elemento RR.
Ao Actual Fecha Proporcionada Interpretada (RR) Interpretada (YY)
1994 27-OCT-95 1995 1995
1994 27-OCT-17 2017 1917
2001 27-OCT-17 2017 2017
2048 27-OCT-52 1952 2052
2051 27-OCT-47 2147 2047

Observe que los valores mostrados en las dos ltimas filas de la tabla anterior. Conforme nos
acercamos a la mitad del siglo, el comportamiento de RR puede que no sea lo que desea.

Oracle Database: Conceptos Fundamentales de SQL I 3-22


Formato de Fecha RR (continuacin)
Estos datos se almacenan internamente de la siguiente forma:
CENTURY YEAR MONTH DAY HOUR MINUTE SECOND
19 87 06 17 17 10 43
Siglos y el Ao 2000
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Cuando se inserta un registro con una columna de fecha en una tabla, la informacin de siglo se
selecciona de la funcin SYSDATE. Sin embargo, cuando la columna de fecha se muestra en la
pantalla, el componente de siglo no aparece (por defecto).
El tipo de dato DATE utiliza 2 bytes para la informacin de ao, uno para el siglo y otro para el ao.
El valor de siglo siempre se incluye, independientemente de si se especifica o se muestra. En este
caso, RR determina el valor por defecto para el siglo en INSERT.

Oracle Database: Conceptos Fundamentales de SQL I 3-23


Uso de la Funcin SYSDATE

SYSDATE es una funcin que devuelve:


Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Fecha
Hora

SELECT sysdate
FROM dual;
;

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Uso de la Funcin SYSDATE


SYSDATE es una funcin de fecha que devuelve la fecha y hora actuales del servidor de base de
datos. Puede utilizar SYSDATE como si utilizara cualquier otro nombre de columna. Por ejemplo,
puede mostrar la fecha actual seleccionando SYSDATE de una tabla. Es muy comn seleccionar
SYSDATE de una tabla ficticia denominada DUAL.
Nota: SYSDATE devuelve la fecha y hora actuales definidas para el sistema operativo en el que
reside la base de datos. Por lo tanto, si est en algn lugar de Australia y se conecta a una base de
datos remota en una ubicacin de Estados Unidos (EE. UU.), la funcin sysdate devolver la
fecha y hora de EE. UU. En ese caso, puede utilizar la funcin CURRENT_DATE que devuelve la
fecha actual en la zona horaria de la sesin.
La funcin CURRENT_DATE y otras funciones de zona horaria relacionadas se abordan con mayor
detalles en Oracle Database: Conceptos Fundamentales de SQL II.

Oracle Database: Conceptos Fundamentales de SQL I 3-24


Operadores Aritmticos con Fechas
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Sumar o restar un nmero de una fecha para obtener un


valor de fecha resultante.
Restar dos fechas para obtener el nmero de das entre
esas fechas.
Agregar horas a una fecha dividendo entre el nmero de
horas entre 24.

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Operadores Aritmticos con Fechas


Debido a que la base de datos almacena fechas como nmeros, puede realizar clculos utilizando
operadores aritmticos como la suma y la resta. Puede agregar y restar constantes numricas y
fechas.
Puede realizar las siguientes operaciones:

Operacin Resultado Descripcin


fecha + nmero Fecha Suma un nmero de das a una fecha
fecha nmero Fecha Resta un nmero de das de una fecha
fecha fecha Nmero de das Resta una fecha de otra
fecha + nmero/24 Fecha Suma un nmero de horas a una fecha

Oracle Database: Conceptos Fundamentales de SQL I 3-25


Uso de Operadores Aritmticos
con Fechas
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

SELECT last_name, (SYSDATE-hire_date)/7 AS WEEKS


FROM employees
WHERE department_id = 90;

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Uso de Operadores Aritmticos con Fechas


El ejemplo de la diapositiva muestra el apellido y el nmero de semanas durante las que han
trabajado todos los empleados del departamento 90. Resta la fecha de contratacin del empleado de
la fecha actual (SYSDATE) y divide el resultado entre 7 para calcular el nmero de semanas durante
las que ha trabajado el empleado.
Nota: SYSDATE es una funcin SQL que devuelve la fecha y hora actuales. Los resultados pueden
ser diferentes segn la fecha y hora definidas para el sistema operativo de la base de datos local al
ejecutar la consulta SQL.
Si se resta una fecha ms actual de una fecha ms antigua, la diferencia es un nmero negativo.

Oracle Database: Conceptos Fundamentales de SQL I 3-26


Agenda
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funciones SQL de una sola fila


Funciones de carcter
Funciones de nmero
Trabajo con fechas
Funciones de fecha

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Oracle Database: Conceptos Fundamentales de SQL I 3-27


Funciones de Manipulacin de Fecha
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funcin Resultado
MONTHS_BETWEEN Nmero de meses entre dos fechas
ADD_MONTHS Agregar meses de calendario a fecha
NEXT_DAY Siguiente da de la fecha especificada
LAST_DAY ltimo da del mes

ROUND Redondear fecha


TRUNC Truncar fecha

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Funciones de Manipulacin de Fecha


Las funciones de fecha funcionan en fechas de Oracle. Todas las funciones de fecha devuelven un
valor del tipo de dato DATE excepto MONTHS_BETWEEN, que devuelve un valor numrico.
MONTHS_BETWEEN(date1, date2): obtiene el nmero de meses entre date1 y date2.
El resultado puede ser positivo o negativo. Si date1 es posterior a date2, el resultado es
positivo; si date1 es anterior a date2, el resultado es negativo. La parte del resultado que no
sea un entero representa una parte del mes.
ADD_MONTHS(date, n): agrega el nmero n de los meses de calendario a date. El valor
de n debe ser un entero y puede ser negativo.
NEXT_DAY(date, 'char'): obtiene la fecha del siguiente da de la semana especificado
('char') que le sigue a date. El valor de char puede ser un nmero que representa un da
o una cadena de caracteres.
LAST_DAY(date): obtiene la fecha del ltimo da del mes que contiene date.
Esta lista es un subjuego de las funciones de fecha disponibles. Las funciones de nmero ROUND y
TRUNC tambin se pueden utilizar para manipular los valores de fecha como se muestra a
continuacin:
ROUND(date[,'fmt']): devuelve date redondeado a la unidad especificada por el modelo
de formato fmt. Si se omite el modelo de formato fmt , date se redondea a la fecha ms cercana.
TRUNC(date[, 'fmt']): devuelve date con la parte de la hora del da truncada a la
unidad especificada por el modelo de formato fmt. Si se omite el modelo de formato
fmt,date se redondea a la fecha ms cercana.
Los siguientes modelos de formato se tratan en las lecciones tituladas Uso de Funciones de
Conversin y Expresiones Condicionales:

Oracle Database: Conceptos Fundamentales de SQL I 3-28


Uso de las Funciones de Fecha
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funcin Resultado
MONTHS_BETWEEN 19.6774194
('01-SEP-95','11-JAN-94')
ADD_MONTHS (31-JAN-96',1) '29-FEB-96'
NEXT_DAY ('01-SEP-95','FRIDAY') '08-SEP-95'
LAST_DAY ('01-FEB-95') '28-FEB-95'

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Uso de las Funciones de Fecha


En el ejemplo de la diapositiva, la funcin ADD_MONTHS agrega un mes al valor de fecha
proporcionado 31-JAN-96 y devuelve 29-FEB-96. La funcin reorganiza el ao 1996 como ao
bisiesto y, por lo tanto, devuelve la ltima fecha del mes de febrero. Si cambia el valor de fecha de
entrada a 31-JAN-95, la funcin devuelve 28-FEB-95.
Por ejemplo, muestre el nmero de empleado, fecha de contratacin, nmero de meses durante los
que ha trabajado, fecha de revisin de seis meses, primer viernes despus de la fecha de contratacin
y ltimo da del mes de contratacin de todos los empleados que han trabajado menos de 150 meses.
SELECT employee_id, hire_date, MONTHS_BETWEEN (SYSDATE, hire_date)
TENURE, ADD_MONTHS (hire_date, 6) REVIEW, NEXT_DAY (hire_date,
'FRIDAY'), LAST_DAY(hire_date)
FROM employees WHERE MONTHS_BETWEEN (SYSDATE, hire_date) < 150;

Oracle Database: Conceptos Fundamentales de SQL I 3-29


Uso de las Funciones ROUND y TRUNC con Fechas

Supongamos SYSDATE = '25-JUL-03':


Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Funcin Resultado
ROUND(SYSDATE,'MONTH') 01-AUG-03
ROUND(SYSDATE ,'YEAR') 01-JAN-04
TRUNC(SYSDATE ,'MONTH') 01-JUL-03
TRUNC(SYSDATE ,'YEAR') 01-JAN-03

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Uso de las Funciones ROUND y TRUNC con Fechas


Las funciones ROUND y TRUNC se pueden utilizar para valores de fecha y nmero. Al utilizarlas con
fechas, estas funciones redondean o truncan el modelo de formato especificado. Por lo tanto, puede
redondear las fechas al ao o mes ms cercano. Si el modelo de formato es mes, el resultado de las
fechas 1-15 es el primer da del mes actual. El resultado de las fechas 16-31 es el primer da del
siguiente mes. Si el modelo de formato es mes, el resultado de las fechas 1-6 es el 1 de enero del ao
actual. El resultado de los meses 7-12 es el 1 de enero del siguiente ao.
Ejemplo:
Compare las fechas de contratacin de todos los empleados que empezaron en 1997. Muestre el
nmero de empleado, fecha de contratacin y mes de inicio con las funciones ROUND y TRUNC.
SELECT employee_id, hire_date,
ROUND(hire_date, 'MONTH'), TRUNC(hire_date, 'MONTH')
FROM employees
WHERE hire_date LIKE '%97';

Oracle Database: Conceptos Fundamentales de SQL I 3-30


Prueba
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Cules de las siguientes afirmaciones sobre funciones de una


sola fila son ciertas?
1. Manipular elementos de datos
2. Aceptar argumentos y devolver un valor por argumento
3. Actuar en cada fila devuelta
4. Devuelve un resultado por juego de filas
5. Posibilidad de modificar el tipo de dato
6. Posibilidad de anidamiento
7. Aceptar argumentos que pueden ser una columna o una
expresin

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Respuesta: 1, 3, 6, 7

Oracle Database: Conceptos Fundamentales de SQL I 3-31


Resumen
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

En esta leccin, debe haber aprendido lo siguiente:


Realizar clculos de datos utilizando funciones
Modificar elementos de datos individuales utilizando
funciones

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Resumen
Las funciones de una sola fila se pueden anidar en cualquier nivel. Las funciones de una sola fila
pueden manipular los siguientes elementos:
Datos de caracteres: LOWER, UPPER, INITCAP, CONCAT, SUBSTR, INSTR, LENGTH
Datos de nmero: ROUND, TRUNC, MOD
Valores de fecha: SYSDATE, MONTHS_BETWEEN, ADD_MONTHS, NEXT_DAY, LAST_DAY
Recuerde lo siguiente:
Los valores de fecha tambin pueden utilizar operadores aritmticos.
Las funciones ROUND y TRUNC tambin se pueden utilizar con valores de fecha.
SYSDATE y DUAL
SYSDATE es una funcin de fecha que devuelve la fecha y hora actuales. Es muy comn seleccionar
SYSDATE de una tabla pblica denominada DUAL.

Oracle Database: Conceptos Fundamentales de SQL I 3-32


Prctica 3: Visin General
Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

En esta prctica se abordan los siguientes temas:


Escritura de una consulta que muestre la fecha actual
Creacin de consultas que requieran el uso de funciones
numricas, de carcter y de fecha
Realizacin de clculos de aos y meses de servicio de un
empleado

Copyright 2010, Oracle y/o sus filiales. Todos los derechos reservados.

Prctica 3: Visin General


Esta prctica proporciona una variedad de ejercicios que utilizan diferentes funciones que estn
disponibles para tipos de dato de carcter, de nmero y de fecha.

Oracle Database: Conceptos Fundamentales de SQL I 3-33


Unauthorized reproduction or distribution prohibited Copyright 2016, Oracle and/or its affiliates

Vous aimerez peut-être aussi