Problema en consulta sql
Hola,
Tengo problemas con una consulta sql que lanzo desde delphi a una bd access (en si la consulta si la lanzo desde acces tambien da el mismo problema asi que no es problema de delphi) Los datos en access estan importados de una hoja excell. La hoja excell, no tiene en todas las columnas datos, asi que podemos encontrar en alguna columna blancos - ahí el problema La cosa, es que no se de que manera puedo tratar esos blancos ya que he probado de todo En acces todos los campos estan definidos como texto: el campo tlf2 de algun registro contiene texto... Supongamos que la hoja excell tiene: Código:
NOMBRE DIRECCION TELEF1 TELEF2 Código:
edit1.text, edit2.text,edit3.tex,edit4.text Código:
Código:
procedure Tform1.Edit1KeyUp(Sender: TObject; var Key: Word; Código:
procedure Tform1.Edit1KeyUp(Sender: TObject; var Key: Word; Código:
edit1.text:= 'jsc' Código:
NOMBRE DIRECCION TLF1 TLF2 Código:
NOMBRE DIRECCION TLF1 TLF2 pienso que el problema esta en la tabla excell y en esos campos en blanco. Tendria manera de saber esos blancos realmente que valor almacenan para poder tratarlos en una consulta? o lamentablemente, a esos valores en blanco tendria que asignarles un valor en excell? por ejemplo "0"? lo he probado asi y si que funciona la consulta; el problema es que son alrededor de 30.000 registros y es un problema si no se el valor que almacena como blanco para poder hacer un Código:
UPDATE... Siento la chapa; he intentado detallar el problema lo maximo posible por si alguien pudiera ayudarme gracias de antemano |
Hola jsc.
Si buscas que muestre resultados cuando encuentre una ocurrencia al menos en uno de los campos, proba de este modo:
Saludos. |
Cita:
lo he solucionado como me temia; he editado el fichero excell y usando reemplazar en todas las columnas; he sustituido las celdas que contengan solo blanco por un 0. de esta manera funciona; la cuestion es que me interesa no tener que hacer este proceso ya que con otros datos que importo tambien desde excell me ocurriria lo mismo y se puede convertir en una perdida de tiempo interesante el tener que adaptar el fichero excell y demas. alguna idea? PD. a la hora de pasar los datos de excell a acess me ha pasado que haciendo un simple copiar pegar no me ha funcionado bien. hay datos que no los pasaba correctamente; quiza por el volumen de datos no se. haciendo importar datos externos y siguiendo el asistente, todo correcto |
Cual son los resultados no esperado, cual es la SQL que has escrito, los que dice ecfisa es correcto y no debes de tener ningún problema.
Da igual que el campo este en blanco o incluso sea nulo, cuando se cumpla uno de los OR te lo va a mostrar. Un saludo |
Cita:
quiza no me explique del todo bien probe lo que comentaba ecfisa y me funciono bien pero solo si encontraba una coincidencia. si hay varias coincidencias no me devuelve bien el resultado. en el ejemplo que puse arriba: Código:
edit1.text := '%jsc%' //valor de nombre Código:
nombre direccion tlf1 tlf2 Código:
nombre direccion tlf1 tlf2 Código:
sql.add ('SELECT * FROM TABLA') ; si edit2 no contiene datos, entonces, el valor de ('direct') tendria que ser todo; para ello se me ocurre hacerlo como en el ejemplo y pasar al parametro ('direc') que contenga cualquier valor y con el resto de los edit lo mismo sino otra alternativa que se me ocurre puede ser algo asi: Código:
query1.sql.add ('SELECT * FROM TABLA') busco una consulta concatenando varios parametros se me ocurrio hacerlo de esta manera quiza no es la correcta?aunque si reemplazo como digo los blancos por algun texto funciona perfecto |
Hola jsc, hice una prueba con la función Nz pero solo funciona desde Access, hice la prueba también con la función "IIF", al parecer también funciona si es que entendido bien lo que preguntas, has la prueba y nos cuentas.
Saluditos |
Cita:
Lo pruebo y comento resultados |
1 Archivos Adjunto(s)
gracias a todos los las ayudas pero no lo consigo
probe tambien lo que comentaba Caro pero tampoco me funciono Código:
sql.add (' where IIF(ISNull(NOMBRE like :nomb),NOMBRE,'+chr(39)+chr(39)+') AND'+ pongo un programita donde vereis lo que quiero y como lo hago quiza no lo este haciendo bien y aqui podreis ver mas en detalle el tema gracias nuevamente |
1 Archivos Adjunto(s)
Hola de nuevo,
aburrido de probar con la funcion IIF... algo se acercaba a lo que pretendia pero no daba con el correcto funcionamiento cambie de metodo y consegui lo que me pretendia en un principio pense que todo esto seria mas facil; en fin de todo se aprende dejo el codigo y el programa de como a mi me ha funcionado por si a alguien le ocurre lo mismo PROPOSITO: lanzar una consulta con los parametros que haya en 1,2,3... los edit que sean solucionado si el campo es Null... devuelve las coincidencias de los edit gracias a los que se interesaron por mi consulta; codigo de la funcion: Código:
function fAsigParamconsul (str:string):string; Código:
strconsul:=fAsigParamConsul ('SELECT * FROM TABLA1') |
La franja horaria es GMT +2. Ahora son las 11:07:14. |
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