Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   Pasar valores a variable String separados por coma (https://www.clubdelphi.com/foros/showthread.php?t=61339)

Dclase 04-11-2008 16:10:41

Pasar valores a variable String separados por coma
 
Saludos primeramente...

A ver si alguien me hecha una manito con un problemita que tengo.

Estoy tratando de pasar unos parametros a una variable String, pero debe ir separado por como, Ej: 'P6','P7'. esto para usarlo en una sentencia con IN.

Este es mi codigo:
CommandText :=
Código SQL [-] 'Select ILINVN,ILORD,ILSAL1,ILCUST,CNME,CAD1,ILWHS,LDESC,ILODPX,ILCONS' + ' From V61BPCSF.SIL' + ' Left Join V61BPCSF.RCM On ILCUST=CCUST' + ' Left Join V61BPCSF.IWM On LWHS=ILWHS' + ' Where ILINVN IN (:Facturas)' + ' And ILODPX IN (:Prefijos) ' + ' And ILWHS=:Almacen'+ ' Group By ILINVN,ILORD,ILSAL1,' + 'LCUST,CNME,CAD1,ILWHS,LDESC,ILODPX,ILCONS';

Params.ParamByName('Facturas').AsString := Trim(Edit2.Text);
Params.ParamByName('Prefijos').AsString := Trim(Edit1.Text);
Params.ParamByName('Almacen').AsString := Trim(txAlm_Salida.Text);

El problema es que el ILODPX debe recibir el valor por ejemplo: 'P6','P7' en la variable delphi ":Prefijos", pero si lo paso como texto normal, cuando el compilador lo pasa, le pasa solo: 'P6,P7', sin las comillas intermedias, y si lo hago manual para que la variable tome 'P6','P7', igual me da el error: TRUNCAMIENTO A LA DERECHA DE DATOS DE TIPO CARACTER, o UNA VARIABLE DE RETORNO ES DEMASIADO PEQUEÑA PARA RECIBIR EL VALOR...
lo mismo me hace con ":Facturas", pero solo cuando son mas de un valor,
si solo paso 'P6' lo hace bien, pero cuando separo con coma y agrego otro se raja.

la base de datos es DB2 en un AS400, lo que en modo de diseño, cuando conecto un DataSet y le paso los parametros, se ejecuta bien, y si en el cuarpo de codigo le pongo directamente los valores, tambien lo hace bien, solo no me funciona cuando paso los valores a una variable.

si alguien saba algo al respecto y me puede ayudar, please..

droguerman 04-11-2008 16:27:04

Debes construir la cadena SQL sin parametros en una variable de texto "manualmente" y ejecutarla.

SAludos

ContraVeneno 04-11-2008 16:34:59

Puedes crear la cadena manualmente sin son pocos. Si son muchos o si no sabes cuantos o cuales van a ser, puedes agregar los elementos mediante un ciclo (for o while) a una variable TStringList (utilizando el método Add) y una vez que tengas todos, puedes usar la propiedad "CommaText" para obtener la lista de valores y usarla en tu consulta SQL:

Código Delphi [-]
UnQuery.SQL.Add('where valores in ('+UnStringList.CommaText+')');

Dclase 04-11-2008 16:41:24

Asi lo hice, pero me sigue tirando el error:
[IBM] [Controlador ODBC de iSeries Access] Columna 2: CWB0111 - un almacenamiento intermedio pasado a una llamada al sistema es demasiado pequeño para contener los datos de retorno.

Caro 04-11-2008 16:47:52

Hola, muestranos el codigo donde estas formando la cadena, la que va recibir el In.

Saluditos

Dclase 04-11-2008 17:05:29

He armado la cadena de varias formas, como decia ContraVeneno, con un TStringList, tomando cada valor uno a uno y almacenandolo en un String y, directamente pasandole a Params.ParamByName('Prefijos').AsString el valor desde un TEdit, y lo pongo de todas formas, con comillas, sin comillas, con coma, sin coma y sigue igual, solo si es un solo parametro me funciona.

Cuando le doy a Debug y voy viendo los valores que toman las variables, estan como deberian, por ejemplo 'P6','P7', pero igual me sigue fallando. solo si le pongo los parametos fijos dentro del codigo ahi si me funciona ( ' And ILODPX IN (''P6'',''P7'') ' + ), pero fijo no me sirve.

droguerman 04-11-2008 17:36:34

Ok, solución alternativa
 
concatenas todos los valores con un separador (por ejemplo /). Por lo tanto, tus valores P6, P7 y P8 los envias así: /P6/P7/P8.

Luego tu comparacion será así:
Código SQL [-]
And Locate('/'+ILODPX, :Prefijos)>0


Saludos

Dclase 04-11-2008 17:55:01

Ok, he descubierto algo que me parece que podria ser por donde ande el problema y es que en la definicion del campo ILODPX es Char(2), si le paso una variable por ejemplo:
'P6P', me devuelve el mismo error, solo que en el IN deberia de asimilarlo como de dos posiciones cada parametro ('P6','P7', dos cadenas de 2) y parece que lo estuviera tomando como un solo String ('P6,P7' una cadena de 5).

Si saben algo relacionado..


La franja horaria es GMT +2. Ahora son las 00:38:48.

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