FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
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í:
Pero cuando corro este código dice que hay un error de sintaxis en el from. Gracias. Aanil |
#3
|
||||
|
||||
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:
// Saludos |
#4
|
||||
|
||||
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. o bien A ver si no me equivoco. Saludos
__________________
Siempre Novato |
#5
|
|||
|
|||
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. |
#6
|
||||
|
||||
Cita:
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. |
#7
|
||||
|
||||
Cita:
Cita:
// Saludos |
#8
|
|||
|
|||
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 |
#9
|
|||
|
|||
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 |
#10
|
||||
|
||||
Cita:
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. |
#11
|
||||
|
||||
#12
|
|||
|
|||
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;
open; label40.Caption := (FIELDVALUES['practica']); end; end; end. |
#13
|
||||
|
||||
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. |
#14
|
|||
|
|||
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.
Gracias por las ayudas. |
#15
|
||||
|
||||
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. |
#16
|
|||
|
|||
Hola Caral.
Guiandome por el ejemplo que me enviaste hice esto: procedure TForm3.BitBtn3Click(Sender: TObject); begin
end; end; procedure TForm3.BitBtn2Click(Sender: TObject); begin 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 |
#17
|
||||
|
||||
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: Saludos
__________________
Siempre Novato |
#18
|
|||
|
|||
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. |
#19
|
||||
|
||||
Hola
Intentemos lo asi: 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 |
|
|
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 |
|