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
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 12:54:38.


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