Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 10-12-2004
subzero subzero is offline
No confirmado
 
Registrado: ene 2004
Ubicación: Móntería - Córdoba - Colombia
Posts: 289
Poder: 0
subzero Va por buen camino
Unhappy substr???

Un saludo a todos en el foro.

Alguien podría ayudarme ya que estoy tratando de utilizar la función substr en interbase 6.0 pero no funciona, ya la adicione a mi base de datos desde el archivo de text ib_udf.txt y aparece, pero resulta que cuando estoy generando una consulta simple

SELECT SUBSTR(CAMPO,1,2)
FROM TABLA


me aparece el siguiente error:

fmSQLEditor.Query:
Invalid token.
invalid request BLR at offset 63.
function SUBSTR is not defined.
module name or entrypoint could not be found.

Si pueden colaborarme se los agradesco
Responder Con Cita
  #2  
Antiguo 10-12-2004
Avatar de marcoszorrilla
marcoszorrilla marcoszorrilla is offline
Capo
 
Registrado: may 2003
Ubicación: Cantabria - España
Posts: 11.221
Poder: 10
marcoszorrilla Va por buen camino
Aunque en estos momentos no tengo documentación a mano, creo recordar que la función a utilizar para estos casos es Extract.

Un Saludo.
__________________
Guía de Estilo de los Foros
Cita:
- Ça c'est la caisse. Le mouton que tu veux est dedans.
Responder Con Cita
  #3  
Antiguo 10-12-2004
subzero subzero is offline
No confirmado
 
Registrado: ene 2004
Ubicación: Móntería - Córdoba - Colombia
Posts: 289
Poder: 0
subzero Va por buen camino
No reconoce el extrae???
Responder Con Cita
  #4  
Antiguo 10-12-2004
subzero subzero is offline
No confirmado
 
Registrado: ene 2004
Ubicación: Móntería - Córdoba - Colombia
Posts: 289
Poder: 0
subzero Va por buen camino
Si alguien sabe un método o una UDf que me pueda extraer una porción de texto de un campo varchar en una consulta se lo agradeceria
Responder Con Cita
  #5  
Antiguo 11-12-2004
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 30
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Smile

¡Hola!

Yo así lo solucioné:

http://www.clubdelphi.com/foros/show...indows+reseteo

Espero esto sea de utilidad, seguimos en contacto.

Al González .
Se busca apartamento con damisela incluída.
Responder Con Cita
  #6  
Antiguo 13-12-2004
subzero subzero is offline
No confirmado
 
Registrado: ene 2004
Ubicación: Móntería - Córdoba - Colombia
Posts: 289
Poder: 0
subzero Va por buen camino
Hola soy yo nuevamente aun no he encontrado la manera de hacer la extración de texto en interbase, probe con la ayuda anterior pero persiste el mismo error


Help...Help...Help...Help
Responder Con Cita
  #7  
Antiguo 13-12-2004
subzero subzero is offline
No confirmado
 
Registrado: ene 2004
Ubicación: Móntería - Córdoba - Colombia
Posts: 289
Poder: 0
subzero Va por buen camino
Lightbulb

Por fin pude solucionarlo... al momento de hacer el llamamiento de la función la declare de la siguiente forma:


DECLARE EXTERNAL FUNCTION extraer
CSTRING(32767), SMALLINT, SMALLINT
RETURNS CSTRING(32767) FREE_IT
ENTRY_POINT 'IB_UDF_substr' MODULE_NAME 'ib_udf';

El número de "32767" es cambiado para aumentar la longitud de almacenamiento

Quizas, a alquien le pueda servir o a mí mismo algun día

Y a todos gracias por interezarse
Responder Con Cita
  #8  
Antiguo 14-12-2004
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 30
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Smile

¡Hola a todos!


Cita:
Empezado por subzero
..."32767"...para aumentar la longitud...
Tengo una duda respecto a ésto último. He notado que la declaración predeterminada de varias funciones con parámetros CString es de longitud 80, cuando la misma documentación aclara que ésta longitud puede aumentarse.

No estoy seguro, pero tengo la sensación de que el servidor Firebird se encarga de reservar un bloque de memoria de longitud + 1 bytes, para convertir parámetros VarChar o Char a CString antes de llamar a la función UDF.

Si esto es así, significa que entre mayor sea la longitud especificada, mayor es el consumo de memoria (y tiempo) del servidor Firebird al llamar a una UDF. Y que por ello, la longitud predeterminada viene muchas veces con un valor ligero, como 80.

Como les comento, esto es solo la impresión que tengo del por qué de la diferencia entre las longitudes aludidas.

Les agradecería cualquier aclaración al respecto.

Al González.

El principal ingrediente de una persona son los brazos que la rodean, incluyendo los suyos propios.
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 18:13:22.


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