FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Problemas con query y parametros
Buenas gente esto lo hice con las ayuda de los foros y seria lo que necesito para un query pata que me imprima.
Esto me dice Invalid parameter, me podrian decir a que se puede deber?
En ese codigo nececitaria realizar una operacion y mostarla, nesecitaria calcular los campos de la tabla facdetalle CANTIDAD* PRECIO, como precioneto, lei que se pone AS PRECIO NETO, pero no se como definir cantidad y precio Todas esas condiciones quiero que se cumplan segun mi el form que trabaje antes que seria el que llama al query, donde tengo las variables tipofac y numfac que serian los que tienen guardado el ultimo nro de factura y el tipo que fue el ultimo que postie. como ahria esa condicon, tendria que definir parametros no? el tema es que no puedo porque lo de arriba me da error.
Desde ya muchas gracias. |
#2
|
||||
|
||||
__________________
|
#3
|
||||
|
||||
Primero y principal:
Creo que está mal hecho el sql. La forma correcta de hacerlo debería ser así:
Tambien deberías tener en cuenta el orden en que haces los joins. Sobre todo si son left o right join. En este caso deberías poner primero From Facturas (porque filtras por su número y tipo) y esta factura unirla al resto de tablas (detalle,cliente,stock) Tambien veo que no utilizas la tabla stock. Quizás no debas meterla en este select.
Última edición por duilioisola fecha: 21-11-2007 a las 21:48:41. |
#4
|
|||
|
|||
Muchas gracias
Gracias gente, pongo en un boton de imprimir la sentencias que me dieron y funciona de 10, evidentemente tenia un problema con la comprension de la sintaxis, a paesar que medio cerca estuve . Todo esto es nuevo para mi.
Una cosa mas les queria pedir, Como relaciono estoo para que me lo muestre en un quick report? Lo que hice gue agregar en la propiedad las sentencias que me dieron, entonces, al cativar el query se me agregaron todos los campos. Hice el diseño, Puse un Page header, y puse los campos de la factura, que serian los fijos, una banda de detal, en dodne puse los encabezados de Codigo, cantidad, precio, precio neto. Y un page footer donde van los detalles de la factura. EL query puse que se abra el query con los aprametros, pero no me aparece nada. COmo se haria? Desde ya muchas gracias |
#5
|
||||
|
||||
Enlaces el QuickReport al query que estas abriendo con la propiedad "Dataset" del quickreport.
Luego, enlazas cada uno de los QRDBText que tengas a su campo correspondiente, utilizando las propiedades "Dataset"y "DataField"
__________________
|
#6
|
|||
|
|||
Gracias contarveneno
Sabes eso, lo tengo bien conectado, tanto los campos como con los dbtext y el dataset del qreport vinculado a al quety1.
Pero no logro que funcione. Seguro que no hago bien cuando lo muestro, aqui explico, el codigo que me corregiste, lo puse en la propiedad sql del query, de esta manera
Los parametros Nrofact y tipo fact los defini en la propiedad params del query.
y Luego en el boton en el que posteo y actualizo el stock al final le ingrese el codigo de arriba. Que me esta faltando, lo unico que veo son 3 campos currency, de descuento, total, y subtotal, con el text en 0,00. Desde ya muchas gracias |
#7
|
||||
|
||||
qrfactura.Query1.Open;
Esa línea no se para que sirve, el query1 no esta en el qrFactura, esa línea me tiene confundido. Deberías de abrir primero el Query1 y despues hacer el preview, bueno, sí lo estas haciendo, pero el Query1 no es parte de qrFactura... solo que qrFactura sea el formulario.... no se supongo que debería ser:
__________________
|
#8
|
|||
|
|||
Gracias por responder, el query1 lo tengo en el quick repor que se llama qrfactura.
Lo que me estaba fijando que en eso me falto asignarle el valor a los dos parametros, ParamByName('NroFact').AsString := NumFac; ParamByName('TipoFact').AsInteger := TipoFac; Le agregue las dos lineas que me habias puesto antes, y aun asi n anda. Sera porque el query1 lo tengo que poner en el formulario y no en un for con el reporte? Numfac y tipo fac las tengo como variables globales que tienen guardada la ultima factura. |
#9
|
||||
|
||||
no pongas el query con el quickreport
ponlo en el formulario principal o puedes usar un módulo de datos
__________________
|
#10
|
|||
|
|||
Buenas gente aca de nuevo, realmente no se que es lo que puede estar pasando, las sentencias sql estan bien y uso el siguiente codigo para asignarle valores a los parametros y no me da error, ni nada, asigne a todos los dbtext el query2 que es el que corresponde y al reporte le asigno el dataset que es el query2.
Que mas puede ser, porque lo unico que hace es mostrarme el form del reporte pero no aparece nada! uso este codigo, realmente no le encuentro error, como me dijo contraveneno, y tampoco veo nada raro, cuando me fijo en las propiedades del query me aparecen lo dos parametros 0-nrofact y 1-tipofact este es el codigo sql
este es el codigo para acceder al reporte
Lo que hice es convertir las variables numfa y tipofa y mostrarlas en dos qrlabel para comprobar que si tiene los valos que quiero y si los tienen. Que se puede estar escapando? Gracias, disculpen la molestia. |
#11
|
|||
|
|||
Buenas gente, yo de nuevo, disculpen, se que me ayudaron bastante, pero estoy haciendo lo mismo una y otra vez y no logro que me muestre en un reporte los datos que le pido, nada da error, que me puede estar faltando, existe algo mas por hacer para hacer funcionar un reporte, es la primera vez que hago una factura, hasta ahora vine haciendo listados simples sin consultas.
Gracias y disculpen si actualizo el hilo... |
#12
|
||||
|
||||
Antes de seguir, asegúrate de que el select que has puesto devuelve valores.
Imagina que haces esto Tabla facturas Código:
Factura campo1 campo2 campo3 1 AAA BBB CCC 2 AAA BBB DDD 3 JJJ KKK LLL 5 EEE DDD NNN
Luego le dices que el parámetro factura = 4
No te devuelve nada porque no hay ningún registro con factura=4 Última edición por duilioisola fecha: 23-11-2007 a las 18:49:12. |
#13
|
||||
|
||||
Cambia la línea:
qrfactura.preview; por qrfactura.previewModal; Preview permite seguir ejecutando las líneas de código, por lo que ejecutará qrFactura.Free destruyendo el informe que quieres visualizar, por ello no ves nada en el informe. Con PreviewModal, el código se queda parado hasta que se cierre la ventana de previsualizar, y después, se continúa el código. Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
#14
|
|||
|
|||
Gracias por los consejos, pero al crear el reporte le pase los valres que necesito los de los dos parametros y si me sale, 11 y A que son el numero de factura y el tipo.
Lepe probe poniendo el previewmodal; en vez de .preview y nada! aca pongo el codigo del boton en el que guardo y quiero imprimir la factura, disculpen si no esta bien programado, es que es mi primer sistemita de prueba. Despues lo ordenare un poco, Lo que me interesa es que me guarda las en las tablas factura y facturadetalle...tambien me descuenta el stock. Acepto criticas sobre tabulacion y en caso de que muy desordenado.
Desde ya muchas gracias por su atencion. Última edición por Petolansa fecha: 23-11-2007 a las 20:41:15. |
#15
|
||||
|
||||
Para guardar se usa tabla.Post, pero tú has usado ¿tabla.Insert? ¿insertar un nuevo registro? ... eso provocará guardar el registro actual, pero no creo sea correcto.
El "case" ese grande, se resume en este:
El fallo que comentas no lo veo, pero "numfa" no veo donde se le asigna el valor. Además veo algunos .Insert innecesarios (ya que crea registros en blanco), como por ejemplo aquí:
Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. Última edición por Lepe fecha: 23-11-2007 a las 23:25:54. |
#16
|
||||
|
||||
Una pregunta tonta, porque estos tipos de fallos suelen ser tan tontos que no los vemos. ¿En el quickreport tienes qrdbtext en la banda detalle con el nombre del campo y su dataset asignado? Porque si los qrLabels muestran los datos correctos, los qrdbtext también lo debería hacer.
Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
#17
|
|||
|
|||
Gracias lepe por tomarte el tiempo de leer el codigo, la erdad que me ahorre un monton de codigo con la sentencia que me pasaste para el nro de factura.
Respecto a lo que em decis de los qrdbtext, en la banda de detalle no los tenia. Los agregue y nada. Las variables numfa y tipofa les asigno los valores en otro form que me lleva a este ultimo, por lo visto las variabls no estan vacias, porque en el reporte me aparece. La verdad no se que puede ser.
Ese codigo me devuelve todos los campos bien y en el reporte lo que hice fue lo siguiente Agregue un pageheader, Donde puse los datos de la fctura como, codigicliente(clicod), tipo de factura(tipofac), Cleinte telefono(clitel), numero de factura(numfactura), etc... Luego un column header, con los nombres de la columna codipro, cantidad, concepto y precio. Luego una banda de detalle, y como me dijiste le ingrese los mismos qrdbext de los de column header (no se si esta bien asi). Osea los copie y pegue Y luego un summary con subtoal, importetotal, descuento, efectivo(monto en efectivo), ctacte (cuenta corriente). Todos con el dataset apuntando al quey2. con su datafield correspondiente. el dataset de quick report apuntando a al query 2. El query dos esta en el form que detalle arriba, Cuando hago click en params, aparecen nrocfact y tipofac, que son a los que luego le asigno numfa y tipofa en el codigo sql del reporte. La verdad no entiendo que puede ser, como te dije es la primera vez que lo hag y no se que puede estar mal! Gracias |
#18
|
|||
|
|||
Me acabo de dar cuenta que no estan establecidos campos claves en las tabla factura y ningun indice con facdetalle, para realizr esta operacion puede ser que tenga que ver algo con los indices o con una relacion maestro detalle o no?
Dsculpen si nada que ver Saludos |
#19
|
||||
|
||||
La falta de índices y claves primarias tendrá consecuencias de lentitud al realizar las consultas sobre esas tablas. En toda Base de Datos, es necesario sus claves primarias y algunos índices por los campos más buscados.
Cuando dices que no te aparece nada en el Preview, exactamente ¿qué ves?, es decir, verás el folio, los qrlabels, los campos de suma, ¿te aparecen con un cero?, ¿no aparecen? ¿te aparece algún texto que diga "Unknown"? Siento marearte, pero lo tienes perfecto!! Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
#20
|
|||
|
|||
Gracias! , Te comento, llamo al preview del reporte, no me aparece absolutamente nada, la pagina en blanco.
Solamente, me aparecen los qrlabel que son dos, que son los cuales muestro los valores para ver si contienen datos, y efectivamente me aparecen los dos datos. Ante de crear este reporte habia creado otro, en el cual me aparecian con ceros el monto del subtotal, importe total y descuento. Pero luego al hacerlo todo de nuevo, no me aparece absolutamente nada. Yo dudaba de las variables numfa y tipofa, pero me doy cuenta que sí contienen datos...la verdad no se, hasta el momento haciendo este proyectito me costo pero anduvo todo, y esto realmente me esta trabandod e una manera impresionante. Que queda por comprobar!! Gracias por el tiempo. Agradecido Gracias Última edición por Petolansa fecha: 26-11-2007 a las 15:18:54. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Ordenar un query por parametros | jzginez | SQL | 11 | 30-10-2007 00:18:02 |
query con parametros ayudenme? | juangabriel1786 | SQL | 4 | 29-08-2007 14:48:49 |
Parámetros en los Query en Delphi for PHP | mlara | PHP | 3 | 13-07-2007 06:56:36 |
Query y Parámetros | gluglu | SQL | 3 | 31-01-2005 13:55:00 |
1 Query - 2 Parametros | azaagh | Conexión con bases de datos | 3 | 13-06-2004 04:59:04 |
|