FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
||||
|
||||
Hola jsc.
Si buscas que muestre resultados cuando encuentre una ocurrencia al menos en uno de los campos, proba de este modo:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#2
|
|||
|
|||
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 |
#3
|
||||
|
||||
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
__________________
Al hacer una consulta SQL, haz que los demás te entiendan y disfruten de ella, será tú reflejo de tú saber. Última edición por olbeup fecha: 14-11-2012 a las 13:20:39. |
#4
|
|||
|
|||
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 edit2.text := '%1%'//valor de direccion Código:
nombre direccion tlf1 tlf2 jsc1 direccion1 jsc2 direccion2 Código:
nombre direccion tlf1 tlf2 jsc1 direccion1 Código:
sql.add ('SELECT * FROM TABLA') ; if s<>'todos' then begin sql.add (' where NOMBRE like :nomb AND DIRECCION like :direc AND TELEF1 like :tlf1 AND TELEF2 like :tlf2'); parambyname ('nomb').asstring := '%'+edit1.Text+'%' ; parambyname ('direc').asstring := '%'+edit2.text+'%'; parambyname ('tlf1').asstring := '%'+edit3.text+'%'; parambyname ('tlf2').asstring := '%'+edit5.text+'%' 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') if edit1.text <> '' then begin parambyname('nomb').asstring := edit1.text sql.add (' and NOMBRE like :nomb) end; if edit2.text <>'' then ... 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 Última edición por jsc fecha: 14-11-2012 a las 14:15:46. |
#5
|
||||
|
||||
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
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
#6
|
|||
|
|||
Cita:
Lo pruebo y comento resultados |
#7
|
|||
|
|||
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'+ ' IIF(IsNull(DIRECCION like :direc),DIRECCION,'+chr(39)+chr(39)+') AND'+ ' IIF(IsNull(TELEF1 like :tlf1),TELEF1,'+chr(39)+chr(39)+') AND'+ ' IIF(IsNull(TELEF2 like :tlf2),TELEF2,'+chr(39)+chr(39)+')'); parambyname ('nomb').asstring := '%'+edit1.Text+'%' ; parambyname ('direc').asstring := '%'+edit2.text+'%'; parambyname ('tlf1').asstring := '%'+edit3.text+'%'; parambyname ('tlf2').asstring := '%'+edit4.text+'%' 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 |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
problema con una consulta | leofuentes21 | SQL | 6 | 28-02-2011 16:04:27 |
problema con consulta sql | gonza_619 | Varios | 6 | 22-07-2010 19:42:56 |
problema en consulta | metroyd | MySQL | 2 | 09-03-2008 19:35:58 |
Problema con Consulta | Tolón | SQL | 5 | 29-01-2007 23:52:19 |
problema con consulta. | jsanchez | SQL | 2 | 20-05-2003 19:35:55 |
|