FTP | CCD | Buscar | Trucos | Trabajo | Foros |
#1
|
|||
|
|||
2 TADOQueries
Hola,
Tengo el siguiente código delphi con una Tabla relacionada: Adjunto la BD hecha en Access. Me preguntaba: ¿se puede realizar la misma operación con UN SOLO TADOQuery? o ¿Necesariamente debo utilizar los 2 ADOQueries porque son 2 consultas diferentes? (pregunto porque son mis primeros pasos con SQL) Última edición por Deiv fecha: 02-11-2008 a las 16:15:02. |
#2
|
||||
|
||||
Hola
Para mi se puede con un solo query, ya que la sentencia que usas esta en una constante, en vez de llamar al query uno o dos, llamaria a la costante, recuerda que Text elimina todo, asi que se puede usar solo uno. Saludos |
#3
|
|||
|
|||
¿Cómo?
Pues me parece que en la linea: Código Delphi [-]ADOQuery1.Active:= True; no puede existir dos Consultas Activas. Cita:
¿Cuál sería la modificación de mi código para que realice el mismo trabajo con un solo TADOQuery? |
#4
|
||||
|
||||
Hola
Ve por ejemplo un pedacito de mi programa: Aqui con un ADOQuery (QTemp.) llamo primero a la tabla Usuarios cargo los datos en un combobox (CBUsuarios.) y luego con el mismo query llamo a la tabla Estaciones y cargo los datos en CBEstaciones. El concepto que aplicas es esencialmente el mismo, solo que la sentencia sql la pones en una constante, nada mas. Bueno es mi humilde opinion. Saludos |
#5
|
|||
|
|||
En este momento no tengo Delphi a mano, pero probaré tu sugerencia y mañana os comento.
|
#6
|
|||
|
|||
Hola,
Cita:
desactiva la consulta y EMPIEZA de nuevo otra consulta, y si se fijan Yo tengo una línea que dice FIRST después de recorrer todos los registros del segundo bucle, si desactivara la anterior consulta a FALSE cada vez empezara la nueva repitiendo lo mismo. Código:
OBJETO USO TIPO Compu Nueva Externo Compu Vieja Externo Monitor Nuevo Externo Monitor Viejo Externo Tarjetas Nuevas Interno Tarjetas Viejas Interno Pernos Nuevos Interno Compu Nueva TIENE Tarjetas Nuevas Compu Nueva TIENE Tarjetas Viejas Compu Nueva TIENE Pernos Nuevos Compu Vieja TIENE Tarjetas Nuevas Compu Vieja TIENE Tarjetas Viejas Compu Vieja TIENE Pernos Nuevos Monitor Nuevo TIENE Tarjetas Nuevas Monitor Nuevo TIENE Tarjetas Viejas Monitor Nuevo TIENE Pernos Nuevos Monitor Viejo TIENE Tarjetas Nuevas Monitor Viejo TIENE Tarjetas Viejas Monitor Viejo TIENE Pernos Nuevos De repente mi Tabla no esté muy bien encarada (es decir la BD) pero lo que intento es demostrar con este ejemplo lo que quiero hacer con los nombres de compuestos químicos (esa es mi tabla Access). Última edición por Deiv fecha: 26-07-2007 a las 20:15:52. |
#7
|
||||
|
||||
Hola
Perdona mi ignorancia pero sigo sin entender, tal vez analizando el codigo paso a paso lo pueda entender mejor, me ayudas?. Primera parte: Aqui defines una constante y las variables que haran una operacion final. Segunda parte: Identificas las tablas con las constantes y las activas, Con la primera tabla haces que la variable P contenga unos datos de la misma. Tercera Parte: En el mismo ciclo haces que la variable S contenga los mismos datos que la variable P solo que con una una diferencia en el IdTipo, sumas las dos y luego colocas todo en un listBox. No se pero a mi me parece que se repiten un poco de todo, no es asi?. Saludos |
#8
|
|||
|
|||
Hola,
Gracias Caral por preocuparte de mi asunto, disculpa si estoy muy torpe con mis preguntas (quizá inentendibles) es lo que me pasa por ser más novato (autodidacta) que muchos novatos. No tengo conexión a Internet en Casa y me valgo de Cibers, me he percatado que tengo una nueva respuesta tuya, por ello no respondí antes. Toda tu comprensión está clarísima, solo que me parece que no me estoy dejando entender. Quiero hacer algo parecido a: En realidad mi código trabaja con 2 TADOQueries, pero más era la curiosidad (por aprender mejor a programar) de ver si se podía con 1 solo TADOQuery Digo una cosa.... ¿Podrías copiar mi código del post#1 readecuarlo y obtener el mismo resultado pero con 1 solo TADOQuery? Última edición por Deiv fecha: 27-07-2007 a las 00:34:53. |
#9
|
||||
|
||||
Hola
Que problema ser mas novato que el que pregunta, pero bueno, si te animas. Me extraña la palabra Guardo, donde guardas, supongo que en memoria, porque no veo que sea en ninguna tabla. Ahora a tu curiosidad, casi estoy convencido que se puede hacer lo que quieres con una sentencia sql distinta en un solo query, pero no veo el porque preocuparse de tener 2 query en un form para una misma consulta. Como soy mas novato que tu y tambien autodidacta en ocasiones he usado mas de dos querys en una consulta, por lo menos al inicio, casi un año. Yo no me preocuparia de estas cosas, seguiria adelante, sobre todo porque funciona, y con el tiempo te daras cuenta de mas cosas, se llama practica, nos pasa a todos. Me parece muy bien tu curiosidad, pero no lo veo como algo grave que te tenga que preocupar ahora, para mi vas mejor que yo. Saludos |
#11
|
||||
|
||||
Lastimosamente concuerdo con el amigo Caral con lo de "dejarlo pues funciona", pero no por "iniciar" en programación, pues si te metiste a hacerlo es porque puedes; si no porque es importante tener en mente que si quieres volverlo "perfecto", perderás la relación costo - beneficio y acabarás quemando tu cerebro y muchas horas en optimización.
Paradójicamente y al igual que tu me gusta que las cosas queden lo más parecido a perfecto (¿?) posible; asi que si estas dispuesto vamos a analizar las alternativas. Por lo que tengo entendido quieres hacerlo todo simplemente con una sentencia SQL; en tal vaso te dejo la siguiente corrección:
No dejes de comentarnos como te va! Edito: Tambien debemos ver cual de las dos alternativas es la más optima. En ESTE caso lo es la última por usar solo un bucle, pero si trabajamos en red debemos analizar qué es lo mas importante, pues con ésta le estamos reduciendo trabajo a las PCs Clientes; con tu solución le aumentamos un poco a las mismas, pero en teoria le reducimos algo al Servidor. Última edición por cHackAll fecha: 27-07-2007 a las 02:26:59. |
#12
|
|||
|
|||
Gracias cHackAll,
Como indique no tengo conexión a un Internet y en este momento estando en un Ciber no tengo acceso a Delphi, probaré tu propuesta, luego les comento además he podido observar que el código sql de tu consejo se ha vuelto un poco mas extenso (en línea), hummmm, veremos. Saludos |
#13
|
|||
|
|||
Cita:
No sé donde está la falla...... |
#14
|
||||
|
||||
Claro que si probe el código y funciona a la perfección. Me parece que la posible causa es el diseño de la BD, pues yo trabajé a ciagas... (suponiendo los campos)... en todo caso pásame los campos + ejemplos; y lo que se debería visualizar y veremos que sucede en realidad.
PD: Delphi7 + ADO + Access 2003, BD 2000 Saludos |
#15
|
|||
|
|||
Hola,
Disculpa si respondo de tiempo en tiempo, lo q sucede me valgo de un Ciber para conectarme a Internet (no os extrañeis) Los Campos en Access está ahí en el archivo adjunto que puse en el primer post ForADO, el ejemplo completo (hecho en Delphi) lo adjuntaré mas tarde ya que en este momento no lo dispongo. |
#16
|
|||
|
|||
Aquí dejo el código en Delphi+BD en Access,
Haber si le echas una miradita Ok? Y si comparas con el código que me mencionaste, y le cambias como dije AND por OR, notarás la diferencia. |
#17
|
||||
|
||||
Es una lástima pero el Club aún tiene dificultades técnicas con los datos adjuntos. Sube tu archivo de nuevo aquí (es la ftp del club realizada por Dec), me dejas el link y lo vemos mañana...
PD: no te preocupes por los retrazos en las repuestas... yo entiendo muy bien esto de los cafes interneeeee (yo estoy en uno ahora) Saludos |
#18
|
||||
|
||||
Ahí lo acabo de poner
(¿es la ftp o el ftp?) // Saludos |
#19
|
||||
|
||||
|
#20
|
|||
|
|||
El código Funciona.
|
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Trabajar Con TAdoTables o TAdoQueries!?? | kman | Varios | 4 | 29-12-2005 12:16:37 |
|