InicioArticulos y noticiasBases de datosProgramaciónForosInternetServiciosContratacionEmail
Tutorial PL/SQL
Introducción a PLSQL
Programación con PL/SQL
Fundamentos de PL/SQL
Tipos de datos en PL/SQL
Operadores en PL/SQL
Estructuras de control en PL/SQL
Bloques PL/SQL
Cursores en PL/SQL
Cursores Implicitos en PL/SQL
Cursores Explicitos en PL/SQL
Cursores de actualización en PL/SQL
Excepciones en PL/SQL
Excepciones personalizadas en PL/SQL
Propagacion de excepciones en PL/SQL
Subprogramas en PL/SQL
Procedimientos almacenados en PL/SQL
Funciones en PL/SQL
Triggers en PL/SQL
Subprogramas en bloques anónimos
Paquetes en PL/SQL
Registros PL/SQL
Tablas PL/SQL
Tipo VARRAY
BULK COLLECT
Transacciones con PL/SQL
Transacciones autónomas
SQL Dinamico
Funciones integradas de PL/SQL
Secuencias
PL/SQL y Java
También puedes ver ...
Excepciones personalizadas en PL/SQL
Como conectar a ORACLE con Java
Recuperar datos BLOB de ORACLE
Trabajar con datos de tipo BLOB en ORACLE
PL/SQL y Java
Secuencias
Transacciones autónomas
SQL Dinamico
Funciones integradas de PL/SQL
Transacciones con PL/SQL

Afiliados
La Web del programador
MundoProgramacion


 

Tipos de datos en PL/SQL

   Cada constante y variable tien un tipo de dato en el cual se especifica el formato de almacenamiento, restricciones y rango de valores validos.

    PL/SQL proporciona una variedad predefinida de tipos de datos . Casi todos los tipos de datos manejados por PL/SQL son similares a los soportados por SQL. A continuación se muestran los TIPOS de DATOS más comunes:

  • NUMBER (Numérico): Almacena números enteros o de punto flotante, virtualmente de cualquier longitud, aunque puede ser especificada la precisión (Número de digitos) y la escala que es la que determina el número de decimales.

    -- NUMBER [(precision, escala)]
    saldo NUMBER(16,2); 
    /* Indica que puede almacenar un valor numérico de 16
    posiciones, 2 de ellas decimales. Es decir, 14 enteros
    y dos decimales */

  • CHAR (Caracter): Almacena datos de tipo caracter con una longitud maxima de 32767 y cuyo valor de longitud por default es 1


    -- CHAR [(longitud_maxima)]
    nombre CHAR(20);
    /* Indica que puede almacenar valores alfanuméricos de 20
    posiciones */

  • VARCHAR2 (Caracter de longitud variable): Almacena datos de tipo caracter empleando sólo la cantidad necesaria aún cuando la longitud máxima sea mayor.



    -- VARCHAR2 (longitud_maxima)

    nombre VARCHAR2(20);
    /* Indica que puede almacenar valores alfanuméricos de hasta 20
    posicones */
    /* Cuando la longitud de los datos sea menor de 20 no se
    rellena con blancos */

  • BOOLEAN (lógico): Se emplea para almacenar valores TRUE o FALSE.


    hay_error BOOLEAN;

  • DATE (Fecha): Almacena datos de tipo fecha. Las fechas se almacenan internamente como datos numéricos, por lo que es posible realizar operaciones aritmeticas con ellas.
  • Atributos de tipo. Un atributo de tipo PL/SQL es un modificador que puede ser usado para obtener información de un objeto de la base de datos. El atributo %TYPE permite conocer el tipo de una variable, constante o campo de la base de datos. El atributo %ROWTYPE permite obtener los tipos de todos los campos de una tabla de la base de datos, de una vista o de un cursor.
  • PL/SQL también permite la creación de tipos personalizados (registros) y colecciones(tablas de PL/SQL), que veremos en sus apartados correspondientes.

   Existen por supuesto más tipos de datos, la siguiente tabla los muestra: 

Tipo de dato / Sintáxis Oracle 8i Oracle 9i Descripción
dec(p, e) La precisión máxima es de 38 dígitos. La precisión máxima es de 38 dígitos. Donde p es la precisión y e la escala.

Por ejemplo: dec(3,1) es un número que tiene 2 dígitos antes del decimal y un dígito después del decimal.

decimal(p, e) La precisión máxima es de 38 dígitos. La precisión máxima es de 38 dígitos. Donde p es la precisión y e la escala.

Por ejemplo: decimal(3,1) es un número que tiene 2 dígitos antes del decimal y un dígito después del decimal.

double precision
float
int
integer
numeric(p, e) La precisión máxima es de 38 dígitos. La precisión máxima es de 38 dígitos. Donde p es la precisión y e la escala.

Por ejemplo: numeric(7,2) es un número que tiene 5 dígitos antes del decimal y 2 dígitos después del decimal.

number(p, e) La precisión máxima es de 38 dígitos. La precisión máxima es de 38 dígitos. Donde p es la precisión y e la escala.

Por ejemplo: number(7,2) es un número que tiene 5 dígitos antes del decimal y 2 dígitos después del decimal.

real
smallint
char (tamaño) Hasta 32767 bytes en PLSQL.

Hasta 2000 bytes en Oracle 8i.

Hasta 32767 bytes en PLSQL.

Hasta 2000 bytes en Oracle 9i.

Donde tamaño es el número de caracteres a almacenar. Son cadenas de ancho fijo. Se rellena con espacios.
varchar2 (tamaño) Hasta 32767 bytes en PLSQL.

Hasta 4000 bytes en Oracle 8i.

Hasta 32767 bytes en PLSQL.

Hasta 4000 bytes en Oracle 9i.

Donde tamaño es el número de caracteres a almacenar. Son cadenas de ancho variable.
long Hasta 2 gigabytes. Hasta 2 gigabytes. Son cadenas de ancho variable.
raw Hasta 32767 bytes en PLSQL.

Hasta 2000 bytes en Oracle 8i.

Hasta 32767 bytes en PLSQL.

Hasta 2000 bytes en Oracle 9i.

Son cadenas binarias de ancho variable.
long raw Hasta 2 gigabytes. Hasta 2 gigabytes. Son cadenas binarias de ancho variable.
date Una fecha entre el 1 de Enero de 4712 A.C. y el 31 de Diciembre de 9999 D.C. Una fecha entre el 1 de Enero de 4712 A.C. y el 31 de Diciembre de 9999 D.C.
timestamp (fractional seconds precision) No soportado por Oracle 8i. fractional seconds precision debe ser un número entre 0 y 9. (El valor por defecto es 6) Incluye año, mes día, hora, minutos y segundos.

Por ejemplo: timestamp(6)

timestamp (fractional seconds precision) with time zone No soportado por Oracle 8i. fractional seconds precision debe ser un número entre 0 y 9. (El valor por defecto es 6) Incluye año, mes día, hora, minutos y segundos; con un valor de desplazamiento de zona horaria.

Por ejemplo: timestamp(5) with time zone

timestamp (fractional seconds precision) with local time zone No soportado por Oracle 8i. fractional seconds precision debe ser un número entre 0 y 9. (El valor por defecto es 6) Incluye año, mes día, hora, minutos y segundos; con una zona horaria expresada como la zona horaria actual.

Por ejemplo: timestamp(4) with local time zone

interval year (year precision) to month No soportado por Oracle 8i. year precision debe ser un número entre 0 y 9. (El valor por defecto es 2) Período de tiempo almacenado en años y meses.

Por ejemplo: interval year(4) to month

interval day (day precision) to second (fractional seconds precision) No soportado por Oracle 8i. day precision debe ser un número entre 0 y 9. (El valor por defecto es 2)

fractional seconds precision debe ser un número entre 0 y 9. (El valor por defecto es 6)

Incluye año, mes día, hora, minutos y segundos.

Por ejemplo: interval day(2) to second(6)

rowid El formato del campo rowid es:

BBBBBBB.RRRR.FFFFF donde BBBBBBB es el bloque en el fichero de la base de datos; RRRR es la fila del bloque; FFFFF es el fichero de la base de datos.

El formato del campo rowid es:

BBBBBBB.RRRR.FFFFF donde BBBBBBB es el bloque en el fichero de la base de datos; RRRR es la fila del bloque; FFFFF es el fichero de la base de datos.

Datos binarios de ancho fijo. Cada registro de la base de datos tiene una dirección física o rowid.
urowid [tamaño] Hasta 2000 bytes. Hasta 2000 bytes. Rowid universal. Donde tamaño es opcional.
boolean Válido en PLSQL, este tipo de datos no existe en Oracle 8i. Válido en PLSQL, este tipo de datos no existe en Oracle 9i.
nchar (tamaño) Hasta 32767 bytes en PLSQL. Hasta 2000 bytes en Oracle 8i. Hasta 32767 bytes en PLSQL. Hasta 2000 bytes en Oracle 9i. Donde tamaño es el número de caracteres a almacenar. Cadena NLS de ancho fijo.
nvarchar2 (tamaño) Hasta 32767 bytes en PLSQL. Hasta 4000 bytes en Oracle 8i. Hasta 32767 bytes en PLSQL. Hasta 4000 bytes en Oracle 9i. Donde tamaño es el número de caracteres a almacenar. Cadena NLS de ancho variable.
bfile Hasta 4 gigabytes. Hasta 4 gigabytes. Localizadores de archivo apuntan a un objeto binario de sólo lectura fuera de la base de datos.
blob Hasta 4 gigabytes. Hasta 4 gigabytes. Localizadores LOB apuntan a un gran objeto binario dentro de la base de datos.
clob Hasta 4 gigabytes. Hasta 4 gigabytes. Localizadores LOB apuntan a un gran objeto de caracteres dentro de la base de datos.
nclob Hasta 4 gigabytes. Hasta 4 gigabytes. Localizadores LOB apuntan a un gran objeto NLS de caracteres dentro de la base de datos.


Inicio | Tutorial PL/SQL Fundamentos de PL/SQLTutorial PL/SQLOperadores en PL/SQL Versión para imprimir Foros de consulta

 
Agradecimiento por Raúl Gracia
Respuesta recibida el [08/06/2007 12:30:16]
Muchísimas gracias por hacer más fácil mi trabajo diario.

 
Otros lo hicieron por mí antes... por Devjoker
Respuesta recibida el [08/06/2007 01:07:14]
Otros lo hicieron por mí antes ... Gracias a tí.

 
Eres un caso tío por Byron
Respuesta recibida el [12/06/2007 04:54:03]
Hola tío, eres un tipo sin egoísmo al compartir su conocimiento, además esto es claro y conciso.

GRACIAS!!!

 
Viva el conocimiento libre por Aitorman
Respuesta recibida el [19/06/2007 12:31:45]
Soy estudiante de 3º de Ingeniería Informática y creeme, que estos tutoriales están muy bien para todo aquel que quiera adquirir conocimientos de programación de una forma clara y fácil. Mi más sincera enhorabuena, sigue así!

Ah, y también destacar que con este proyecto, avivas el conocimiento libre, lo cual es de agradecer.

 
Excelente por Sónico
Respuesta recibida el [24/06/2007 05:16:29]
Este tipo de información 
ayuda muchisímo a Uno.

Excelente JOB

 
Muy bueno, gracias por Guille
Respuesta recibida el [17/09/2007 02:57:08]
Gracias por compartir vuestros conocimientos, saludos!

 
exelente por damian
Respuesta recibida el [04/10/2007 05:38:50]
Soy estudiante de Lic. en computación y sistemas en 5o. semestre, buscando tutoriales para este lenguaje me topé con el tuyo, exelente trabajo, se te agradece por compartir el conocimiento y evitar el egoismo. Siempre hay que ayudarnos para ser mejores.. saludos!!

 
estupendo tutorial por javi
Respuesta recibida el [15/10/2007 09:05:00]
Yo soy programador Java y hace poco he tenido que vermelas con el pl/sql. 
Tu manual me ha dejado muchas cosas claras. Va al grano y no se pierde en tecnicismos innecesarios.
Un saludo y gracias!!!

 
sigue adelante por willy
Respuesta recibida el [19/10/2007 11:40:02]
muy bueno en compartir esos concimentos tuyos me esta ayudando en mi carrera q llevo de ingenria de sistemas aca en lima - peru 
si es posible agrega otras versiones antiguas de oracle en tipo de datos tipo una historia
gracias

 
Gracias por William
Respuesta recibida el [21/11/2007 08:02:54]
Soy estudiante de ingenieria de sistemas de 4to semestre y en realidad estos tutoriales han sido de una gran utilidad, muy bien hechos, claros....
No me queda mas que agradecerte por compartir esta informacion.

 
Grande maestro por hdemente
Respuesta recibida el [22/01/2008 03:15:51]
Los conocimientos que dejas en este sitio me sacan de muchos apuros y de verdad se nota que eres secopara el tema, poruqe de lo contrario no compartirias tus conocimientos.

vale tio.

 
GRACIAS!!! por Daniel
Respuesta recibida el [12/06/2008 01:54:58]
la verdad te agradezco que hayas colgado este conocimiento en la red, me es de mucha ayuda.

 
ayuda por naye
Respuesta recibida el [22/06/2008 05:50:11]
quisera saber que necesito y cmo instalar oracle para practicar pl/sql en mi casa??
porfavor una brebe respuesta
gracias

 
Sysdate por Melisa
Respuesta recibida el [16/07/2008 03:47:50]
Cuando tengo:
Select sysdate from dual;

que fecha me trae? la de mi equipo, la del servidor donde esta instalado oracle?
De donde la saca?

Gracias.


Añadir comentario ... Para preguntar utiliza los foros
Autor:

Título:


Para preguntar utiliza los foros.



Inicio | Tutorial PL/SQL Fundamentos de PL/SQLTutorial PL/SQLOperadores en PL/SQL Versión para imprimir

Tipos de datos en PL/SQL
Autor: Pedro Herrarte Sánchez
Visitas: 67153 Fecha de publicación: 31/03/2006
Pedro Herrarte, es consultor independiente, ofreciendo sercivios de consultoría, análisis, desarrollo y formación.

Posee mas de diez años de experiencia trabajando para las principales empresas de España.

Es especialista en tecnologías .NET, entornos Web, bases de datos (SQL Server y ORACLE) e integración de sistemas.

Es experto en desarrollo (C#, ASP.NET, VB.Net, T-SQL, PL/SQL, , ASP, CGI , C, Pro*C, Java, Essbase, Vignette, PowerBuilder y Visual Basic ...) y bases de datos (SQL Server y ORACLE).

Es fundador, diseñador y programador de www.devjoker.com.




18/08/2008 SQL Server 2008
Visitas: 39 | Comentarios: 0 | Archivo: Articulos
Categorias: Transact-SQL
Visitas: 131 | Comentarios: 0 | Archivo: Articulos
Categorias: C#|ADO.NET|LinQ
Visitas: 161 | Comentarios: 1 | Archivo: Articulos
Categorias: Humor
Visitas: 154 | Comentarios: 0 | Archivo: Articulos
Categorias: WCF
Visitas: 123 | Comentarios: 0 | Archivo: Articulos
Categorias: WCF
Visitas: 210 | Comentarios: 0 | Archivo: Articulos
Categorias: ASP.NET
Visitas: 278 | Comentarios: 5 | Archivo: Articulos
Categorias: ASP.NET
Visitas: 4990 | Comentarios: 4 | Archivo: Articulos
Categorias: C#|Transact-SQL|LinQ
Visitas: 602 | Comentarios: 1 | Archivo: Articulos
Categorias: Visual Studio
Visitas: 1402 | Comentarios: 1 | Archivo: Articulos
Categorias: Transact-SQL

Útimos temas recibidos en los foros ...
Y lo mismo en WEB por systemat ... [C#] 1 18/08/2008
Manual del minicom de Linux con fotos. por Meta ... [UNIX] 4 17/08/2008
PROGRAMACION por JUANMA ... [Visual Basic .NET] 1 19/08/2008
Conectar ASP con B.D Informix por Franco ... [ASP] 9 02/05/2007
Codigo salir por Jazmin ... [ASP.NET] 1 18/08/2008
EXPORTAR DATOS A ARCHIVOS PLANOS. por WIX ... [ORACLE] 10 06/08/2007
formulario por artdark ... [C#] 2 04/08/2008
Codigo salir por Jazmin ... [ASP.NET] 0 18/08/2008
cambiar de modo un gried view por ivan ... [ASP.NET] 0 18/08/2008
ayuda urgente porfavor por vicancer ... [ASP.NET] 0 18/08/2008
pollo por hajaj ... [Actualidad] 1 15/08/2008
DIOS TE BENDIGA por El You ... [WIN 98/NT/2000/XP] 1 16/08/2008

Access CGI JSP ORACLE UNIX
Actualidad HTML/DHTML/XHTML LINUX PHP Visual Basic .NET
ASP ISAPI MS DOS Power Builder Visual Basic 6.0
ASP.NET Java mySQL SQL WIN 98/NT/2000/XP
C# JavaScript Opinion SQL Server

devjoker  Te recomendamos además ...
11/09/2006 Trabajar con datos de tipo BLOB en ORACLE
06/07/2007 ¿Qué es el RSS?    forma parte de...Tutorial RSS
26/07/2006 Secuencias    forma parte de...Tutorial PL/SQL
18/10/2005 Enviar emails a través de un servidor SMTP autenticado con Java
08/09/2007 Funciones en Transact SQL    forma parte de...Tutorial de Transact SQL
12/01/2006 Introducción a PLSQL    forma parte de...Tutorial PL/SQL
08/07/2008 Fiddler - Indispensable para el desarrollo Web
13/08/2007 Reiniciar un campo identity en SQL Server
22/10/2005 Introducción SQL    forma parte de...Tutorial SQL
03/10/2006 Fundamentos de C#    forma parte de...Tutorial C#

 

Encuesta
Si trabajas con .NET ¿Que entorno utilizas?
[Ver] [Votar]