FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
como enlazar un query con un dbgrid
hola que tal soy nuevo en esto y agradeceria la ayuda que se me pueda dar a traves de este medio.
mi problema es como enlazar un query con el dbgrid. en la forma tengo un database, query, datasource y un dbgrid espero que alguien pueda ayudarme, gracias |
#2
|
||||
|
||||
Hola Jact y Bienvenido al CLub, mira es muy sencillo, me imagino que sabes algo de SQL dado que estas utilizando el componente Query (por cierto olvidaste decir que base de datos utilizas), en la propiedad SQL del query pones la sentencia, en el datasource en la propiedad Dataset seleccionas el Query, en el DBGrid en la propiedad Datasource seleccionas el datasource que tiene el query, activas el query y listo, asi de facil no? bueno ya nos comentas como te va.
Saludos.
__________________
Mi BLOG - ¡Joder, leanse la guia de estilo! Las Palabras son enanas, los ejemplos gigantes. |
#3
|
|||
|
|||
gracias por la respuesta, olvide mencionar que la base de datos esta en phpmyadmin y ay un problema al enlazarlos de la forma que me dijiste. porque en el datasource en la propiedad dataset no encuentra al query. y si elimino el datasource y lo vuelvo a poner en la propiedad dataset si encuentra al query pero en el query en la propiedad datasource no encuentra nada
espero y se entienda el problema gracias |
#4
|
||||
|
||||
Hola Jact cuales componentes estas utilizando para conectarse a mysql? supongo que estas utilizando los componentes zeos. que son para bases de datos mysql.
Saludos.
__________________
Mi BLOG - ¡Joder, leanse la guia de estilo! Las Palabras son enanas, los ejemplos gigantes. |
#5
|
||||
|
||||
Cita:
dbgrid.Datasource := datasource1; Datasource1.Dataset := query1; Y se acabó. Query1.Datasource es para enlazar 2 consultas en relación Maestro-Detalle, y eso no tiene nada que ver con lo que has dicho. SAludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
#6
|
|||
|
|||
solucionado
gracias a todos por su ayuda ya los pude enlazar asi como lepe menciono
gracias y saludos a todos |
#7
|
|||
|
|||
HOLA,
Tengo un problema parecido a este, ojala me puedan ayudar (bueno el mio es tan tonto que me da verguenza)...bueno todo esta así, leo un valor en un Edit(Marca), conforme este cambie en su propiedad Text me debe de realizar una consulta a la tabla Modelos(asociados a la tabla Marca)...la consulta como resultado me debe arrojar todos los registros de modelos asociados a esa marca y me llena un DBGrid, pero no hace. El DBgrid esta asociado a un Tquery llamado QBusca2 y un TDataSource (DBuscar2)...este es el códido FPMarcas.QBusca2.Close; FPMarcas.QBusca2.SQL.Clear; FPMarcas.QBusca2.SQL.Add ('Select ID_MODELO, NOMBRE_MODELO from T_MODELO_X_MARCA where ID_MARCA ' ); FPMarcas.QBusca2.SQL.Add (' in (Select Id_MARCA from CAT_MARCA where NOMBRE_MARCA LIKE arametro)'); FPMarcas.QBusca2.ParamByName('parametro').asString := FPMarcas.DBNombre_Marca.Text + '%'; FPMarcas.QBusca2.ExecSQL; FPMarcas.QBusca2.Open; Ahh mi Base de Datos esta en Access........de verdad es tan tonto y no lo puedo hacer...me doy un tiro verdad? |
#8
|
||||
|
||||
Pues será tan tonto el error que pasa desapercibido, lo único que sobra es la línea "FPMarcas.QBusca2.ExecSQL;", lo demás parece estar bien.
Siempre que hagas un "Select" de una tabla, usa Open para abrirla. ExecSql se usa para sqls de tipo (Update, insert, delete), por ejemplo: "Update mitabla set campo = valor where condicion" Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
#9
|
|||
|
|||
Gracias Lepe, funcionó a la perfección.
Una vez más me haz salvado....sé que se oye un poco dramatico, pero ayer estuve cerca de 2 horas intentandolo y ya estaba de muy mal humor. |
#10
|
|||
|
|||
Perdona que te moleste de nuevo, tengo una duda similar quiero hacer lo mismo con un comboBox, pero no me queda...la pregunta es, se hace lo mismo...porque no me queda.
FPAutomoviles.QMarca.SQL.Text:='SELECT NOMBRE_MARCA FROM CAT_MARCA WHERE ID_MARCA LIKE :PARAMETRO'; FPAutomoviles.QMarca.ParamByName('PARAMETRO').Value := FPAutomoviles.DBMarca.Text; FPAutomoviles.QMarca.Active:=true; while not FPAutomoviles.QMarca.Eof do begin FPAutomoviles.DBMarca.Items.Add(FPAutomoviles.QMarca.Fields[0].text); FPAutomoviles.QMarca.Next; end; Se supone que leé 'ID_MARCA', el cual es el valor del combo(en este caso solo es un item) y conforme a este me hace la consulta para traerme el nombre de la marca....lo tengo en un combo porque posteriormente (al momento de agregar un registro) deseo que me devuelva todos los registros de una tabla, lo cual tampoco hace, que puede ser? Nota....perdona que lo lo haya agregado a otro hilo. |
#11
|
|||
|
|||
Cita:
Estas buscando datos en una tabla con el valor que tienes en un ComboBox (imagino que ahí seleccionas el ID_MARCA), pero despues quieres meter todos los dato que encuentras con esa consulta en el mismo ComboBox diferente a ID_MARCA Puedes aclaranos eso por favor... Salud OS |
#12
|
|||
|
|||
Hola, perdona que no me halla explicado. Más o menos esto es lo que debo hacer.
1. Tengo un ComboBox(Marcas) en un Formulario, este esta asociado a un field(Nombre) de la Tabla (Automoviles), con el style = csSimple. 2. Cuando lo ejecuto me muestra el ID de la marca(porque es el que esta guardado en la tabla Automoviles). 3. Mediante una consulta quiero que consulte la Tabla Marca y me devuelva como resultado el nombre de la marca, es decir, deseo que el usuario visualice el nombre de la marca, no el Id. 4. Cuando el usuario presione le boton 'Nuevo' o 'Editar', entonces se realizará una consulta a la tabla Marca y me devolverá todos los nombres de las marcas. 5. Automáticamente cuando seleccione un nombre se relizará otra consulta, pero ahora a la tabla Modelos y se llenará un segundo ComboBox(Modelos) con todos los registros relacionados con esa Marca. - el style cambiará a 'csDropDown' 6. Posteriormente deberé guardar los valores seleccionados en mi Tabla original(Automóviles). Espero me halla explicado, y me puedas ayudar. Sé que es un básico y sencillo pero no me sale...lo peor es que se supone que soy programadora (sin experiencia ni lógica, es obvio). |
#13
|
||||
|
||||
Eso mismo lo hace el componente TDBLookUpComboBox, quizás te simplifique las cosas, ya que llena el combo con todos los items.
Creo me falta el nombre de una tabla, así que me la invento. Supongamos que tienes una tabla Seguros_de_automoviles, y ahí quieres guardar la marca y modelo de un automovil asegurado, claro, solo vamos a guardar el id_marca y el id_modelo, porque las descripciones están en las tablas AUTOMOVILES y MODELOS respectivamente. En el DBLookupcombobox tendrías que asignar las siguientes propiedades en el inspector de objetos Datasource := un datasource a la tabla seguros_de_automoviles Field := un campo de la tabla seguros_de_automoviles que se llama id_marca (será clave ajena o foránea de la tabla automoviles) ListSource := un query con: 'SELECT id_marca, NOMBRE_MARCA FROM CAT_MARCA WHERE ID_MARCA LIKE :PARAMETRO order by NOMBRE_MARCA' ListField:= NOMBRE_MARCA; KeyField := id_marca; Como digo, eso guarda en la tabla seguros_de_automoviles el id de la marca, pero el combobox mostrará los nombres de las marcas. No borres los componentes que usas ahora mismo, ya que puede que no te guste (en estética o uso) esta nueva forma. Haz las pruebas y tu misma decides. ¿y por qué digo esto?, porque en el DBLookupCombo no se verá el cursor del ratón, y da la impresión de que no permite escribir dentro de él. Saludos.
__________________
Si usted entendió mi comentario, contácteme y gustosamente, se lo volveré a explicar hasta que no lo entienda, Gracias. |
#14
|
|||
|
|||
Si funciona....gracias!!!
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Enlazar varios Combobox a un DBGrid. | Kenlyr | Conexión con bases de datos | 6 | 09-01-2007 23:36:13 |
Problema al enlazar un dbgrid con dos querys diferentes | MiGuEJeReZ | Varios | 7 | 20-06-2006 10:56:22 |
enlazar query, datasource, dbgrid | Diegobdab | Conexión con bases de datos | 2 | 25-08-2005 10:12:24 |
Como puedo hacer una consulta con un Query y que se actualize en el DBGrid | olbeup | SQL | 7 | 01-08-2005 17:37:28 |
¿Como mostrar un campo Memo en un DBGrid de una Query? | judoboy | OOP | 5 | 07-05-2003 04:36:19 |
|