Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros temas > La Taberna
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 24-11-2012
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
No te preocupes, si son burrada soy burro si no hago las cosas como se deben sino uno no aprende.

De entrada si uso esa sentencia es porque hay que asignarle al query la tabla que vas a usar.
y la otra de consultas es para filtrar segun lo que me conviene y luego se la vuelvo a aplicar con * por si tengo que aplicar otra consulta y no me la aplique solo con los registros resultantes de la consulta anterior.

Si no se debe hacer asi, si me das un ligero apunte a ver si me aclaro, porque no se trata de que las cosas funcionen, sino de que funcionen aplicando las reglas como deben de ser.

gracias de nuevo

Esto no es lo que se pone para asignar al inicio?.

Código Delphi [-]
zquery2.SQL.text:='select * from tbeneficiario';
zquery3.SQL.Text:='select * from tcuentas';
zquery1.sql.text:='select * from tcheques';
zquery4.sql.text:='select * from facturas';
 zquery3.Active:=true;
 zquery2.Active:=true;
 zquery4.active:=true;
 zquery1.Active:=true;
 datasource1.DataSet:=zquery1;
 datasource2.dataset:=zquery2;
 datasource3.dataset:=zquery3;
 datasource4.dataset:=zquery4;

Última edición por anubis fecha: 24-11-2012 a las 18:19:21.
Responder Con Cita
  #2  
Antiguo 24-11-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.057
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por anubis Ver Mensaje
Esto no es lo que se pone para asignar al inicio?.
Bueno, no.
Quiero decir lo que he preguntado antes: ¿necesitas para algo traerte todos los campos de todos los registros de todas esas tablas?
Responder Con Cita
  #3  
Antiguo 24-11-2012
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
hombre, de primera no, pero cuando ya se abre el programa, se tienen que ver todos los registros del mes, por ejemplo.

si yo le pongo un select * from, me trae todos, pero sino lo pongo asi, como hago una consulta de todos los registros del mes sino le afecta a todos para que haga el filtrado. Si, eso lo debe hacer en el servidor y luego se bajan los del mes que siempre serán menos.

En lineas generales te entiendo lo que dices, y voy cogiendo la idea, el problema es como asigno primero el query sin ponerle el select * from, y la otra es como hago una consulta directamente en el servidor y traerme esos datos.

Porque si estoy viendo que lo hice todo mal .
Edito: En el caso de las consultas en el servidor, puede ser un procedimiento diretamente en la base de datos del servidor? y simplemente llamarlo?.
El caso inicial al iniciar la aplicacion no se me ocurre que poner en el select quue no sea el *

Última edición por anubis fecha: 24-11-2012 a las 19:11:56.
Responder Con Cita
  #4  
Antiguo 24-11-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.057
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Creo que no entiendo bien. Veamos, si quieres/necesitas traerte una serie de campos de una serie de registros de una tabla, te traes solamente esos.

Código SQL [-]
select campo1, campo42, campo55
from unatabla
where fecha >= '01.11.2012'
order by fecha

Ahí te traes sólamente unos campos que necesitas de una tabla que necesitas y desde una fecha que necesitas, sólamente lo que necesitas.
Responder Con Cita
  #5  
Antiguo 24-11-2012
Avatar de anubis
anubis anubis is offline
Miembro
 
Registrado: mar 2007
Posts: 863
Poder: 18
anubis Va por buen camino
si, eso lo entiendo, solo tengo que pedir lo que realmente necesite, lo que preguntaba es cuando inicio la aplicacion tengo que asignarle la tabla al query, quiere decir que con poner solo un campo ya me sirve?.

Sobre los campos, en un query, desgraciadamente necesito todos, quiza la clave principal no.
Responder Con Cita
  #6  
Antiguo 24-11-2012
Avatar de Casimiro Notevi
Casimiro Notevi Casimiro Notevi is offline
Moderador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.057
Poder: 10
Casimiro Notevi Tiene un aura espectacularCasimiro Notevi Tiene un aura espectacular
Cita:
Empezado por anubis Ver Mensaje
lo que preguntaba es cuando inicio la aplicacion tengo que asignarle la tabla al query, quiere decir que con poner solo un campo ya me sirve?.
No tienes que asignar nada a ningún query cuando inicias la aplicación. Sólamente lo que necesitas.
Responder Con Cita
  #7  
Antiguo 24-11-2012
Avatar de Julián
Julián Julián is offline
Merodeador
 
Registrado: may 2003
Ubicación: en mi casa
Posts: 2.019
Poder: 10
Julián Va por buen camino
Bueno, no te llamaremos burro, pero eso que haces sí que es una burrada.
Es como si teniendo que consultar un libro, pidieras que te trajeran toda la biblioteca. Si la biblioteca está en tu casa, pues ya la tienes ahí. Pero si está en otro edificio tienes que sperar a que la carguen en camiones, y que estos lleguen a tu casa y te la descarguen.

Debes cambiar radicalmentela manera en que haces las cosas: Pide sólo un libro o unos pocos, y te los traerá Casimiro en su moto en dos segundos. Así que hazle caso y olvida el select *.

Vale, y si, como tu dices, ¿los necesitas todos?
En ese caso la soclución también es muy fácil: paginación. Usa una tabla (rejilla o grid o como se diga) con un número limitado de filas, por ejemplo 10, y la rellenas con select * from tabla limit 0,10 (segun la bd podrás usar limit u otra cosa).

Si quieres mostrar un paginador haces un select count para saber el numero total de filas y lo divides por el numero de fials en la rejilla para saber el número de páginas.

Aún así te iría como el puto culo. Por culpa de los campos blobs, que ocupan mucho. Para esto tienes dos socluciones: la mejor es no usar campos blobs y en su lugar guardar el nombre del archivo, el cual solo será enviado al navegador cuando realmente quieras verlo. La otra es no poner un * en el select y en su lugar especificar los campos que no sean blob, y traerte estsos sólo cuando quieras verlos.

Lo que no entoendo es que clase componentes usas, o de que forma lo haces, para que todo eso nque te explico no lo hagan "automáticamente".

Un salaudo!
__________________
"la única iglesia que ilumina es la que arde"
Anonimo

Última edición por Julián fecha: 24-11-2012 a las 22:53:00.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Problemas con conexión a una Base de datos remota. germancbaarg Conexión con bases de datos 1 24-04-2008 20:45:00
Conexión a base de datos remota martinzcr Firebird e Interbase 3 27-08-2007 19:46:00
Conexion remota a Base de datos jorelivi Servers 1 22-06-2007 22:50:11
Lentitud: Conexion a dos bases y dos exe Alexander Conexión con bases de datos 1 13-06-2007 20:28:54
Conexion a Base de Datos Remota juanjoassenza Firebird e Interbase 3 12-03-2005 01:35:00


La franja horaria es GMT +2. Ahora son las 15:26:46.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi