![]() |
![]() |
![]() |
![]() |
![]() |
FTP | ![]() |
![]() |
CCD | ![]() |
![]() |
Buscar | ![]() |
![]() |
Trucos | ![]() |
![]() |
Trabajo | ![]() |
![]() |
Foros | ![]() |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
Herramientas | Buscar en Tema | Desplegado |
#21
|
|||
|
|||
Bueno pues despues de intentar hacer lo que me decis sige sin funcionarme
el codigo es este Código Delphi [-] procedure TAltas.PO(Sender: TObject); begin Con_Art_Bar.Open; Con_Art_Bar.SQL.Clear; Con_Art_Bar.SQL.Add('SELECT Min(Precio) AS minimo, Articulo, Nombre, '); Con_Art_Bar.SQL.Add('Precio, Fecha, Ultimo_precio, Fecha_ultima, Cod_Art'); Con_Art_Bar.SQL.Add('FROM proveedores, articulos'); Con_Art_Bar.SQL.Add('where proveedores.Cod_Proveedor = Articulos.Cod_Proveedor'); Con_Art_Bar.SQL.Add('GROUP BY Articulo, Nombre, Precio, '); Con_Art_Bar.SQL.Add('Fecha, Ultimo_precio, Fecha_ultima, Cod_Art'); Con_Art_Bar.SQL.Add('HAVING Articulo=Foli;'); Con_Art_Bar.Active := True; end; y el error es este que adjunto Última edición por Ubed fecha: 05-11-2007 a las 13:12:54. |
#22
|
||||
|
||||
Hola Ubed,
puedes hacer los siguiente: Ir al menu Tools => Debugger Options => Pestaña Language Exceptions => Desmarcar la casilla que está abajo: Stop On Delphi Exceptions Pruébalo, ya no debería salirte el error. Luego ya nos comentas que más te ocurre. Mira que al ver el error fue lo primero que se me ocurrió además de lo de activar la Query. Saludos |
#23
|
|||
|
|||
Bueno pues el error parece menor (por lo menos ocupa menos).
dice esto: Access violation at address 0047BAC5 in module 'Bolcase.exe'. Read the address 000000D2. |
#24
|
||||
|
||||
A ver que nos estamos liando.
1.- Donde se produce exactamente el error (en que linea de las que has puesto) 2.-
Saludos |
#25
|
|||
|
|||
parece k ya va pero aora kmo recogo el valor de una lista??
yo tengo una lista y kiero k kuando seleccione un valor me cambie el having de la consulta y donde pone foli aparezca ese valor seleccionado. Perdonad por todas las molestias, pero soy muy nuevo |
#26
|
||||
|
||||
Cita:
Ahora llegamos al siguiente punto: - Los parámetros de una query. Para substituir el valor de un campo en la query por un parámetro, para así tener un valor variable, debes substituir ese valor puesto a manor por parámetro con el nombre que tu quieras y precedido por dos puntos. Por ejemplo: :Artic es el parámetro al cual le asignaremos el valor que queramos. Ahora vamos a asignarle un valor Para ello y siempre después de asignar todo el texto de la query y antes de ejecutarla hacemos lo siguiente:
Entre los paréntesis ponemos el nombre del parámetro (sin los dos puntos). Luego hemos puesto AsString para indicarle que el parámetro que le vamos a pasar es de tipo String. Sino es así puedes desplegar las posibles opciones con el codeinsight (Tras el punto espera un poco o presiona Ctrl + Barra espaciadora) y ver los demás tipos que le puedes asignar al parámetro. Luego asignamos al parámetro un valor, en este caso el contenido de un edit. Ojo, el valor asignado debe ser del mismo tipo d edatos que el parámetro, en este caso el text de un edit es de tipo string. Para tú caso particular, debemos saber antes que tipo de objeto estas usando (combobox, listbox, etc). Haz pruebas con esto y ves jugando un poco. Edito: ahora que veo en esta misma sentencia hay un error: No es necesario poner los dos puntos al final de la sentencia, ya que el objeto la cierra automáticamente. |
#27
|
|||
|
|||
Gracias por todo lo k me estas ayudando.
Esta instruccion no me la reconoce. Con_Art_Bar.ParamByName('Artic').AsString := edit.text; Ademas yo lo kiero para una lista. ¿Seria asi? Con_Art_Bar.ParamByName('Artic').AsString := lista_Art.SelectedItem; |
#28
|
||||
|
||||
Cita:
![]() ![]() ![]() Si escribes esto Con_Art_Bar. y empiezas a escribir Param... te aparece en el CodeInsight. si te aparece, ¿entonces que mensaje de error te aparece? Otra cosa, ¿que tipo de objeto es la lista? = TListBox, TComboBox, TOutline, etc, es que dependiendo del objeto puedes acceder al item seleccionado de distintas maneras. Saludos |
#29
|
|||
|
|||
cuando empiezo a escribir me aparece parameter pero no ParamByName
la lista que uso es un DBlookUpListBox |
#30
|
||||
|
||||
Ok, por lo que veo efectivamente debes usar esto
- Escribe por favor el error que te devuelve al compilar. - ¿De que tipo es el objeto Con_Art_Bar? ¿Es un TQuery o descendiente suyo? - Otra cosa, tambien puedes probar con la propiedad Params, que funciona igual que Parambyname, pero en lugar de indicarle el nombre del parámetro que quieres asignarle valor, usas el índice del parámetro. En tu caso sería el 0, ya que es el primer parámetro, si tienes más tendrías que indicarle el orden que ocupa. |
#31
|
|||
|
|||
Ya lo solucione al final ice esto:
Con_Art_Bar.SQL.Add('HAVING Articulo='''+ lista_art.SelectedItem +''''); Con_Art_Bar es un ADOQuery |
#32
|
||||
|
||||
Tambien es una solución.
Una ayuda al respecto, para evitar posibles lios en el futuro con tanta comilla, es usar lo siguiente
Así sólo pones la comilla para finalizar el string y te olvidas de todos los demás. Saludos |
![]() |
|
|
![]() |
|