![]() |
![]() |
![]() |
![]() |
![]() |
FTP | ![]() |
![]() |
CCD | ![]() |
![]() |
Buscar | ![]() |
![]() |
Trucos | ![]() |
![]() |
Trabajo | ![]() |
![]() |
Foros | ![]() |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
![]() 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 ![]() |
#2
|
||||
|
||||
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! |
#3
|
||||
|
||||
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:
Y ¡listo!. Con esto, se mostrará la columna 'Subtotal' mostrando el valor del producto. // Saludos |
#4
|
||||
|
||||
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 |
#5
|
|||
|
|||
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 [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 |
#6
|
||||
|
||||
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 |
#7
|
||||
|
||||
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
// Saludos |
![]() |
|
|
![]() |
|