InicioArticulos y noticiasBases de datosProgramaciónForosInternetServiciosContratacionEmail
También puedes ver ...
SQL Server 2008
LinQ To SQL - Un ejemplo sencillo
Leer un campo XML de SQL Server 2005 con C#
SQL dinámico en Transact SQL
Cursores en Transact SQL
Triggers en Transact SQL
Funciones en Transact SQL
Procedimientos almacenados en Transact SQL
Transacciones en Transact SQL
Variables en Transact SQL

Afiliados
La Web del programador
MundoProgramacion


 

Formatear números en SQL Server

Una duda que suele tener la gente es como formatear los datos numérico es SQL Server - Es bastante común tener que formatear un número completando con ceros hasta un número determinado de posiciones.

Podemos hacer un bucle para concatenar la expresion resultante, pero no parece ni mucho menos la opción mas adecuada.

El siguiente script ilustra una forma más eficiente de conseguir el mismo resultado.

 

DECLARE @num int,

@formato varchar(10),

@expresion varchar(10)

 

SET @formato = '0000000000'

SET @num = 2002

SET @expresion = RIGHT( @formato + cast(@num AS varchar), 10)

SELECT @expresion

La idea es concatenar una expresion de formato fijo - los ceros - con el número a formatear. Posteriormente utilizamos la función RIGHT para recortar los n elementos de la derecha.

La salida de la ejecucion es la siguiente:

 

DATO_FORMATEADO

---------------

0000002002

Como podemos ver, hemos conseguido nuestro objetivo. Por supuesto, este truco es válido también para completar con espacios en blanco - muy util para obtener ficheros de ancho fijo - o cualquier otro tipo de caracter.

Podemos hacer las cosas un poco mejor, y creamos una funcion a la que le pasaremos el número a formatear y el formato de salida.

 

CREATE FUNCTION dbo.FormatNum

(

@number int,

@format varchar(50)

)

RETURNS varchar(50)

AS

BEGIN

DECLARE @len int

SET @len = len(@format)

RETURN RIGHT( @format + cast(@number AS varchar), @len)

END

Sobre  una supuesta tabla Pais, que hemos cargado previamente con cinco registros - con el código autonumérico - ejecutamos la siguiente consulta:

 

SELECT

dbo.FormatNum(CodPais,'000000000000') AS CodPais,

NombrePais,

Activo

FROM

Pais

El resultado de la consulta es el siguiente:


CodPais           NombrePais     Activo
----------------- -------------- ------
000000000001      Pais 0         0
000000000002      Pais 1         0
000000000003      Pais 2         0
000000000004      Pais 3         0
000000000005      Pais 4         0

 Saludos, DJK


 Versión para imprimir  Foros de consulta


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

Título:


Para preguntar utiliza los foros.



 Versión para imprimir

Formatear números en SQL Server
Autor: Pedro Herrarte Sánchez
Visitas: 1992 Fecha de publicación: 03/06/2008
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.




Visitas: 136 | Comentarios: 0 | Archivo: Articulos
Categorias: Visual Basic .NET|C#|ASP.NET|ASP.NET|Programación|ADO.NET
27/09/2008 Navegando ....
Visitas: 59 | Comentarios: 0 | Archivo: Articulos
Categorias: Humor
Visitas: 173 | Comentarios: 0 | Archivo: Articulos
Categorias: Visual Basic .NET|C#|ASP.NET|ASP.NET|Programación|WCF
Visitas: 712 | Comentarios: 0 | Archivo: Articulos
Categorias: C#
Visitas: 178 | Comentarios: 0 | Archivo: Articulos
Categorias: JavaScript|ASP.NET
Visitas: 624 | Comentarios: 0 | Archivo: Articulos
Categorias: Windows XP|Linux|Windows Vista
Visitas: 405 | Comentarios: 0 | Archivo: Articulos
Categorias: Linux|BSD
Visitas: 215 | Comentarios: 0 | Archivo: Articulos
Categorias: Programación|Actualidad
18/08/2008 SQL Server 2008
Visitas: 1033 | Comentarios: 1 | Archivo: Articulos
Categorias: Transact-SQL
Visitas: 732 | Comentarios: 0 | Archivo: Articulos
Categorias: C#|ADO.NET|LinQ

Útimos temas recibidos en los foros ...
COASTAL VACATIONS MEJORA TU ECONOMIA por benigno ... [Access] 0 06/10/2008
OPORTUNIDAD DE NEGOCIO COASTAL VACATIONS por benigno ... [Actualidad] 0 06/10/2008
COASTAL VACATIONS REVOLUCION COMERCIAL por benigno ... [C#] 0 06/10/2008
COASTAL VACATIONS NEGOCIO por benigno ... [C#] 0 06/10/2008
Pasar el contenido de un dataGrid a Excel por Minguial ... [C#] 4 06/03/2008
Crear una sesion de inicio por jhors ... [ASP.NET] 1 06/10/2008
Enviar email a correos cmo hotmail por Cajami ... [C#] 13 06/09/2007
Como mandar mensaje a Celular por Pako ... [C#] 23 13/03/2007
Casting por sara ... [Java] 1 06/10/2008
ORA-22288: file or LOB operation GetLength failed por heroga ... [ORACLE] 1 05/08/2008
Galeria de imagenes en Visual Web Developer por luis ... [ASP.NET] 0 06/10/2008
utilizar un ObjectDataSource por mari90 ... [ASP.NET] 4 25/10/2006

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 ...
04/03/2006 Bloques PL/SQL    forma parte de...Tutorial PL/SQL
23/05/2006 Cursores en PL/SQL    forma parte de...Tutorial PL/SQL
03/10/2006 Creación de objetos    forma parte de...Tutorial C#
18/08/2008 SQL Server 2008
16/08/2007 Borrar datos en Transact SQL    forma parte de...Tutorial de Transact SQL
10/07/2006 Funciones en PL/SQL    forma parte de...Tutorial PL/SQL
07/05/2008 Cómo activar Intelisense (autocompletado) en el Web.config
03/10/2006 Programacion con C#    forma parte de...Tutorial C#
12/01/2006 Introducción a PLSQL    forma parte de...Tutorial PL/SQL
01/08/2007 Actualizar datos en Transact SQL    forma parte de...Tutorial de Transact SQL

 

Encuesta
¿A que perfil te adaptas mejor?
[Ver] [Votar]