Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 05-02-2010
aanil aanil is offline
Miembro
 
Registrado: abr 2006
Posts: 155
Poder: 19
aanil Va por buen camino
Suma por campos

Hola a todos:

Como yo haria para sumar el valor de un campo de la columna A, mas el valor de un campo de la columna B, de una consulta.

Supongo que seria así:

Código SQL [-]
('select sum (A, B) As total from MyTabla');

Pero cuando corro este código dice que hay un error de sintaxis en el from.

Gracias.

Aanil
Responder Con Cita
  #2  
Antiguo 05-02-2010
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
No entiendo:
Código Delphi [-]
('select Sum(TuTabla.A) AS [TotalA], Sum(TuTabla.B) AS [TotalB] from TuTabla');
No se si posteriormente o en la misma consulta queras sumarlos, no entiendo.
Saludos
__________________
Siempre Novato
Responder Con Cita
  #3  
Antiguo 05-02-2010
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
La función Sum sólo puede aplicarse a un campo, porque lo que hace es sumar todos los valores de un mismo campo en toda la tabla o sobre grupos de registros (agrupando la tabla con GROUP BY).

Para lo que quieres basta hacer:

Código SQL [-]
select A + B as total from MyTabla

// Saludos
Responder Con Cita
  #4  
Antiguo 05-02-2010
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Totalmente cierto y por supuesto error mio, visto desde el punto de vista de una suma corriente seria tan sencillo como eso, visto desde el punto de vista de la suma del campo seria con un group By como indica el Maestro Roman.
Código Delphi [-]
('select DISTINCT TuTabla.TuCampodefinido, Sum(TuTabla.A) AS [TotalA],'+
 'Sum(TuTabla.B) AS [TotalB] from TuTabla GROUP BY TuTabla.TuCampodefinido');
o bien
Código Delphi [-]
('select DISTINCT TuTabla.TuCampodefinido, Sum(TuTabla.A) + '+
 'Sum(TuTabla.B) AS [Total] from TuTabla GROUP BY TuTabla.TuCampodefinido');
A ver si no me equivoco.
Saludos
__________________
Siempre Novato
Responder Con Cita
  #5  
Antiguo 05-02-2010
aanil aanil is offline
Miembro
 
Registrado: abr 2006
Posts: 155
Poder: 19
aanil Va por buen camino
Hola.

Es posible que no me diera a entender:

La idea es que en una tabla TEstudiantes consulto un nombre de un estudiante y el mismo tiene las columnas: nota1, nota2, nota3 y yo quiero sumar las notas de ese estudiante consultado, o sea nota1 + nota2+ nota3 y que el resultado de estas notas se presente en un Label o en un TEdit de el formulario donde yo hago la consulta.

A ver si es posible..


Gracias.
Responder Con Cita
  #6  
Antiguo 05-02-2010
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Cita:
Empezado por aanil Ver Mensaje
Es posible que no me diera a entender:

La idea es que en una tabla TEstudiantes consulto un nombre de un estudiante y el mismo tiene las columnas: nota1, nota2, nota3 y yo quiero sumar las notas de ese estudiante consultado, o sea nota1 + nota2+ nota3 y que el resultado de estas notas se presente en un Label o en un TEdit de el formulario donde yo hago la consulta.

A ver si es posible..
Hola aanil, solo tienes que hacer la suma de los campos y recuperar por el alias que le pongas.

Código Delphi [-]
......
Query.Text := 'Select nota1 + nota2+ nota3 As Suma From TEstudiantes ....'
......
 
if Not Query.IsEmpty then
 Label.Caption := Query.FieldByName(Suma).AsString;

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
Responder Con Cita
  #7  
Antiguo 05-02-2010
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por aanil Ver Mensaje
Como yo haria para sumar el valor de un campo de la columna A, mas el valor de un campo de la columna B, de una consulta.
Cita:
Empezado por roman Ver Mensaje
Para lo que quieres basta hacer:

Código SQL [-]
select A + B as total from MyTabla
Cita:
Empezado por aanil Ver Mensaje
Es posible que no me diera a entender:

[...]

A ver si es posible..
Sí te diste a entender y es lo que ya te había contestado.

// Saludos
Responder Con Cita
  #8  
Antiguo 05-02-2010
aanil aanil is offline
Miembro
 
Registrado: abr 2006
Posts: 155
Poder: 19
aanil Va por buen camino
Hola:

Aqui le pongo el codigo completo y siempre me dice que hay un error en la clausa from.

Código:
begin
 with datam.ADOQuery1 do begin
 sql.Add('select a+b+c AS total from Tabla1');
 open;
 label1.Caption := intTostr(datam.adoquery1.fieldBYname('total').asinteger);
 end;
 end;
end.


A ver que es lo que pasa.

Gracias.

Última edición por Casimiro Notevi fecha: 05-02-2010 a las 18:49:32. Razón: poner etiquetas correctamente
Responder Con Cita
  #9  
Antiguo 05-02-2010
aanil aanil is offline
Miembro
 
Registrado: abr 2006
Posts: 155
Poder: 19
aanil Va por buen camino
Código:
begin
  with datam.ADOQuery1 do begin
  sql.Add('select a+b+c AS total from Tabla1');
  open;
  label1.Caption := intTostr(datam.adoquery1.fieldBYname('total').asinteger);
  end;
end;
end.

Última edición por Casimiro Notevi fecha: 05-02-2010 a las 18:50:20. Razón: Poner etiquetas
Responder Con Cita
  #10  
Antiguo 05-02-2010
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Cita:
Empezado por aanil Ver Mensaje
Hola:

Aqui le pongo el codigo completo y siempre me dice que hay un error en la clausa from.

sql.Add('select a+b+c AS total from Tabla1');

A ver que es lo que pasa
Sería muy útil que nos dijeras cuál mensaje de error aparece, es decir, el texto del error que ves en pantalla. Me refiero al error que se despliega en pantalla cuando ejecutas la sentencia SQL.

El problema puede estar en que tus campos no se llaman A, B y C, sino Nota1, Nota2 y Nota3 y muy probablemente tu tabla no se llama Tabla1, sino Estudiantes, o algo por el estilo.

Dinos si te funciona colocando los nombres reales de la tabla y los campos.

Un abrazo selecto.

Al González.
Responder Con Cita
  #11  
Antiguo 05-02-2010
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por Al González Ver Mensaje
Un abrazo selecto.
O bien, una SUMa de abrazos

// Saludos
Responder Con Cita
  #12  
Antiguo 06-02-2010
aanil aanil is offline
Miembro
 
Registrado: abr 2006
Posts: 155
Poder: 19
aanil Va por buen camino
Hola:

Mi tabla se llama 20092, los campos se llaman Nota1, Nota2......Nota5, mi base de datos que esta hecha en access se llama Estudiantes. Los campos Nota1 a Nota5 es de tipo numérico.

El error en principio era ERROR DE SINTAXIS EN FROM. Ahora no me presenta ese error, sino que ahora dice:" Query1: Field 'Matricula' Not found "

Y este es mi real codigo completo.

procedure TForm3.BitBtn2Click(Sender: TObject);
begin
with datam.Query1 do begin
close;

Código SQL [-]
sql.Text := 'select (pract1 + pract2 + pract3 + pract4 + pract5) As practica from 20092'

open;
label40.Caption := (FIELDVALUES['practica']);
end;
end;
end.
Responder Con Cita
  #13  
Antiguo 06-02-2010
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Una muestra EXACTA de lo que tienes.
Funciona perfectamente.
Espero te ayude.
Saludos
__________________
Siempre Novato

Última edición por Caral fecha: 07-02-2010 a las 03:06:46.
Responder Con Cita
  #14  
Antiguo 07-02-2010
aanil aanil is offline
Miembro
 
Registrado: abr 2006
Posts: 155
Poder: 19
aanil Va por buen camino
Hola a todos y en especial a Caral

Todo esta funcionando perfectamente, ahora mi inquietud es que tengo un campo para guardar el resultado de la suma de todas las notas, se llama T_Notas y no se como guardar la suma de esas notas consultadas.

Este es mi codigo que esta funcionando perfectamente.

Código SQL [-]
datam.Query1.SQL.Text := ' select *,(exp + expgrup+ pract1 + pract2+ pract3 + pract4 + pract5) As Practica from 20092';
datam.Query1.Open;
Label40.Caption := IntToStr(datam.Query1 .FieldByName('Practica').AsInteger);

Gracias por las ayudas.
Responder Con Cita
  #15  
Antiguo 07-02-2010
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Me imagino que el campo esta en al misma tabla.
Lo que se hace es recorrer la tabla y hacer un update según el nombre.
Aquí esta el mismo ejemplo con esta modificación.
Saludos
__________________
Siempre Novato

Última edición por Caral fecha: 08-02-2010 a las 03:10:39.
Responder Con Cita
  #16  
Antiguo 07-02-2010
aanil aanil is offline
Miembro
 
Registrado: abr 2006
Posts: 155
Poder: 19
aanil Va por buen camino
Hola Caral.

Guiandome por el ejemplo que me enviaste hice esto:

procedure TForm3.BitBtn3Click(Sender: TObject);
begin

Código SQL [-]
datam.Query1.First;
   while not datam.Query1.Eof do   // recorre la tabla y hace el update
   begin
    datam.Query1. sql.Text := 'Update 20092 set practica = '+datam.Query1Practica.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);
    datam.Query1.SQL.Text := 'Update 20092 set parciales = '+datam.Query1Parciales.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);
    datam.Query1.SQL.Text := 'Update 20092 set calf_final = '+datam.Query1calif_final.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);

    datam.Query1.ExecSQL;
  datam.Query1 .Next;


end;
end;


procedure TForm3.BitBtn2Click(Sender: TObject);
begin
Código SQL [-]
datam.Query1.SQL.Text := ' select *,(exp + expgrup+ pract1 + pract2+ pract3 + pract4 + pract5) As Practica from 20092';
datam.Query1.SQL.Text := ' select *,( parcial1 + pasrcial2) As parciales from 20092';
datam.Query1.SQL.Text := ' select *,( practica + parciales + final) As Calf_final from 20092';
 datam.Query1.Open;
end;

end.


El error se produce en datam.Query1 .Next;

Dice error de sintaxis en la instrucción UPDATE

Mas o menos siento que estoy cerca de llegar al final de mi proyecto, pero me falta algo por comprender.

Sera que debo de usar EQTemp.Sql? y no se de donde sale.

Gracias
Responder Con Cita
  #17  
Antiguo 07-02-2010
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Coloca otro query en el datamodule. (query2)
A este query lo llamas como gustes, yo lo llame EQTemp (ya que lo uso en cualquier lado como temporal, es un query normal y corriente).
Si haces el update en el mismo query borra el contenido del anterior, entonces no encuentra nada y da un error de sintaxis u otros.
No puedes hacer un update sin no hay información, ya la borraste usando el mismo query.
Nada mas pon otro query, asi:
Código Delphi [-]
datam.Query1.First;
   while not datam.Query1.Eof do   // recorre la tabla en el query1
   begin
  // hace el update del query2
    datam.Query2. sql.Text := 'Update 20092 set practica = '+datam.Query1Practica.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);
    datam.Query2.SQL.Text := 'Update 20092 set parciales = '+datam.Query1Parciales.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);
    datam.Query2.SQL.Text := 'Update 20092 set calf_final = '+datam.Query1calif_final.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);

    datam.Query2.ExecSQL; // ejecuta el query2
  datam.Query1 .Next; // recorre el query1 hasta el final
Saludos
__________________
Siempre Novato
Responder Con Cita
  #18  
Antiguo 07-02-2010
aanil aanil is offline
Miembro
 
Registrado: abr 2006
Posts: 155
Poder: 19
aanil Va por buen camino
Hola Caral:

Realmente no entiendo donde es que esta mal porque con tu codigo sigue produciendo el mismo error

Señala en azul este: datam.Query1.Next; // recorre el query1 hasta el final
Y sigue diciendo que es un error de sintaxis.
Que podra ser?

AAnil.
Responder Con Cita
  #19  
Antiguo 07-02-2010
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Intentemos lo asi:
Código Delphi [-]
datam.Query1.First;
   while not datam.Query1.Eof do   // recorre la tabla en el query1
   begin
  // hace el update del query2
    datam.Query2. sql.Text := 'Update 20092 set practica = '+datam.Query1Practica.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);
 datam.Query2.ExecSQL;
    datam.Query2.SQL.Text := 'Update 20092 set parciales = '+datam.Query1Parciales.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);
 datam.Query2.ExecSQL;
    datam.Query2.SQL.Text := 'Update 20092 set calf_final = '+datam.Query1calif_final.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);
 datam.Query2.ExecSQL; // ejecuta el query2

  datam.Query1 .Next; // recorre el query1 hasta el final
Me parece que son varios update y se tienen que ejecutar uno por uno.
Saludos
Pd: Si no funciona se podria colocar un query por update, pero me parece que no se necesario, con solo ejecutarlo servira.
__________________
Siempre Novato
Responder Con Cita
  #20  
Antiguo 07-02-2010
aanil aanil is offline
Miembro
 
Registrado: abr 2006
Posts: 155
Poder: 19
aanil Va por buen camino
Hola

Ahora se para en este punto.

Código SQL [-]
 datam.Query2.SQL.Text := 'Update 20092 set parciales = '+datam.Query1Parciales.AsString+' where matricula = '+QuotedStr(datam.Query1matricula.AsString);

Y dice lo mismo.

No encuentro el problema
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
suma de campos calculados pabloparra Conexión con bases de datos 0 12-03-2008 22:14:12
Suma de dos Campos en un BDGrid esimon SQL 6 14-09-2005 20:50:12
Suma de campos b3nshi Conexión con bases de datos 1 13-04-2005 03:13:40
suma de campos novato cesarjbf SQL 4 01-09-2004 10:12:33
Problema con Suma de Campos TIME en SP cacuna Firebird e Interbase 1 03-09-2003 16:37:38


La franja horaria es GMT +2. Ahora son las 02:46:29.


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