Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-07-2005
ELINK ELINK is offline
Miembro
 
Registrado: mar 2005
Posts: 55
Poder: 20
ELINK Va por buen camino
Algo como LENGTH pero en SQL (FireBird)...

tengo esa duda y la verdad no se como resolverla.
Ojala me puedan ayudar

tengo esta sentencia

select codi_prod from productos where LENGTH(codi_prod) = 11

de debo hacer para que mi cadena pueda funcionar,
teniendo en cuenta que yo quiero que la cantidad de caracteres del resultado sea igual a 11

Gracias de antemano

mi base de datos es FireBird 1.5

Última edición por ELINK fecha: 26-07-2005 a las 03:58:21.
Responder Con Cita
  #2  
Antiguo 26-07-2005
Avatar de Investment
Investment Investment is offline
Miembro
 
Registrado: may 2003
Posts: 378
Poder: 21
Investment Va por buen camino
Post

Bueno, con el SQL_SERVER se usa LEN(codi_prod)
Pruebalo.
__________________
Saludos,
Peter Investment
Responder Con Cita
  #3  
Antiguo 27-07-2005
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 27
jachguate Va por buen camino
En firebird podes valerte de una udf.

Por ejemplo en $firebird$\UDF yo tengo la biblioteca ib_udf.dll y el script ib_udf.sql.

Al correrlo completo te registra 36 funciones para manipulación de cadenas y números entre las que está strlen que sirve para el cometido tuyo.

Luego de registrarla podes usarla en cualquier query.

Has de tener cuidado, eso sí, de que la dll esté accesible al proceso servidor de firebird para que el invento funcione, y a tener una equivalente si pretendes instalarlo en otro sistema operativo. Para las rutas y los nombres me he basado en windows, aunque supongo que en linux vendrá la ib_udf.so, ahora no tengo uno a mano como para comprobarlo.

Hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #4  
Antiguo 27-07-2005
ELINK ELINK is offline
Miembro
 
Registrado: mar 2005
Posts: 55
Poder: 20
ELINK Va por buen camino
Gracias Por responder :-)
yo no se mucho de las UDFs, podrias decirme poco poder registrarla y como va dentro de la sentencia???

Gracias.
Responder Con Cita
  #5  
Antiguo 27-07-2005
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 27
jachguate Va por buen camino
Para registrarla, corré el script que ya mencioné antes. Solo hay que hacerlo una vez (en cada BD que te interese tener disponibles las funciones).

Podes correr el script completo, o bien extraer la sentencia específica para strlen, que en el script de mi instalación es:

Código SQL [-]
DECLARE EXTERNAL FUNCTION strlen
  CSTRING(32767)
  RETURNS INTEGER BY VALUE
  ENTRY_POINT 'IB_UDF_strlen' MODULE_NAME 'ib_udf';

en el caso de strlen, su uso es:

Código SQL [-]
Select codi_prod
  from Productos
 where strlen(codi_prod) = 11;

Hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 20:08:53.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi