Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 21-06-2004
simon simon is offline
Miembro
 
Registrado: jun 2004
Posts: 31
Poder: 0
simon Va por buen camino
Post Multiplicaion de compos en DBGrid

Hola muy buena tarde......


tengo un DBGrid, con tres campos, Cantidad, Precio y subtotal.
lo que quiero hacer es lo siguiente:

Subtotal = Cantidad X precio, pero es usando un DBGrib, como puedo hacerlo.
tengo la idea pero no se como hacerlo.

mucha gracias
Responder Con Cita
  #2  
Antiguo 21-06-2004
Avatar de __marcsc
__marcsc __marcsc is offline
Miembro
 
Registrado: may 2003
Ubicación: Girona
Posts: 577
Poder: 22
__marcsc Va por buen camino
Hola,

no tiene demasiada importancia que tengas un DBGrid. Lo que tendrías que hacer sería crear un campo calculado en el DataSet al cual tienes asociado tu grid.

Saludos!
Responder Con Cita
  #3  
Antiguo 21-06-2004
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
Dado que Subtotal lo quieres obtener a partir de Cantidad y Precio supongo que no se trata de un campo que esté presente en la tabla.

Lo que necesitas es un campo calculado.

En el editor de campos de la tabla agregas un campo nuevo y le indicas que será un campo calculado. En el evento OnCalcFields de la tabla asignas el valor al campo:

Código Delphi [-]
procedure TForm1.Table1CalcFields(DataSet: TDataSet);
begin
  DataSet['Subtotal'] := DataSet['Cantidad']*DataSet['Precio'];
end;

Y ¡listo!. Con esto, se mostrará la columna 'Subtotal' mostrando el valor del producto.

// Saludos
Responder Con Cita
  #4  
Antiguo 21-06-2004
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
Veo que se me adelantó marcsc.

Aprovecho para mandar este hilo al foro de "Conexión con bases de datos" que es más adecuado.

// Saludos
Responder Con Cita
  #5  
Antiguo 22-06-2004
simon simon is offline
Miembro
 
Registrado: jun 2004
Posts: 31
Poder: 0
simon Va por buen camino
gracias por la ayuda probe la rutina pero me esta dando un error y es el siguiente

Código:
 	   Dts_PedidosDetalle['Sub_Total'] :=
Dts_PedidosDetalle['Cantidad_Pedido'] * Dts_PedidosDetalle['Precio_Unitario_Articulo'];
[Error] Un_Pedidos.pas(267): Class does not have a default property
[Error] Un_Pedidos.pas(267): Class does not have a default property
[Error] Un_Pedidos.pas(267): Class does not have a default property
[Fatal Error] SistemaFacturacin.dpr(11): Could not compile used unit 'Un_Pedidos.pas'

Última edición por roman fecha: 22-06-2004 a las 21:21:45. Razón: Una vez más tenía líneas demasiado largas
Responder Con Cita
  #6  
Antiguo 22-06-2004
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Pues los fields que usas no tienen una propiedad por defecto, asi que vas a tener que usar las propiedades Value, o bien AsInteger o AsFloat según corresponda.

dataset['field'].AsFloat (por ejemplo)

Hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #7  
Antiguo 22-06-2004
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
El ejemplo que puse debe funcionar tal cual. La componente TDataSet, y cualquiera de sus descendientes, tiene a FieldValues como propiedad por default. Realmente no sé que se supone que es Dts_PedidosDetalle ni tampóco sé por qué usa éste en lugar del parámetro DataSet que pasa el evento OnCalcFields.

Otra cosa es que no sea muy eficiente usar FieldValues por el uso de variants. Para optimizar habría que poner algo como

Código Delphi [-]
DataSet.FieldByName('Sub_total').AsFloat :=
  DataSet.FieldByName('Cantidad_Pedido')*DataSet.FieldByName('Precio_Unitario_Articulo');

// Saludos
Responder Con Cita
  #8  
Antiguo 23-06-2004
simon simon is offline
Miembro
 
Registrado: jun 2004
Posts: 31
Poder: 0
simon Va por buen camino
muy buen dia, gracias por el code Ramon....

cuando escribo el primer dataSet. este si me permite usar el FieldByName('Campo').AsFloat, pero despues del := en lo campos que quiero calcular no me permite usar el FieldByName si no el FieldByValues.

y si lo folso escribiendolo me da el siguiente erro

[Error] Un_Pedidos.pas(267): Operator not applicable to this operand type

detalles de los campo.

Cantidad = Numerica
Precido = Moneda
Sub_Total = Moneda
calSub_Total = campo calculo

primero quiero multiplicar Sub_total = Cantida * Precio, para luego sumar todos los sub_totales.

espero me entienda mil gracias
Responder Con Cita
  #9  
Antiguo 24-06-2004
simon simon is offline
Miembro
 
Registrado: jun 2004
Posts: 31
Poder: 0
simon Va por buen camino
mucha gracias por la ayuda ya pude resolver el problema, era que estaba declarando el campo calculado como una variable.


gracias y pasen un feliz resto del dia
Responder Con Cita
  #10  
Antiguo 06-07-2004
click click is offline
Miembro
 
Registrado: ago 2003
Posts: 34
Poder: 0
click Va por buen camino
lo que yo no eh podido hacer es el gran total

ya tengo mi campo calculado y ya me da bien los resultados, pero como le hago para el gran total? , hay alguna especie de calcular el total?
__________________
Saludos.
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


La franja horaria es GMT +2. Ahora son las 11:33:57.


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