Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 30-04-2012
IVAND IVAND is offline
Miembro
 
Registrado: may 2003
Ubicación: ECUADOR
Posts: 523
Poder: 21
IVAND Va por buen camino
Ayuda tema presentacion contabilidad en delphi 6

Hola a todos

Tengo un sistema contable que funciona perfectamente ya hace algunos anios , pero ahora un cliente me pidio algo un poco diferente y estoy un poco confundido les explico

tengo un plan de cuentas
ejemplo

1 Activo
1.1 activo fijos
1.1.1 caja
1.1.1.1 caja general

etc

pues bien , esto yo lo tengo en un treview como arbol claro esta tengo otro campo adicional donde se guarda de donde viene la cuenta

ejemplo
11.11.1.11.1.1.1.1 Esta es la cadena que se guarda para caja general
1 para activos
11.1 activos fijos y asi sucesivamente

ahora lo que quiere el cliente es , que si hago una transacccion contable esta muestre los balances acumualados por cuentas ejemplo

tengo 2 asientos contables q tocaron a la cuenta caja
uno de 100 y otro de 200

1 Activo 100
1.1 activo fijos 100
1.1.1 caja 100
1.1.1.1 caja general 100

en el segundo asiento aumentamos 200

1 Activo 300
1.1 activo fijos 300
1.1.1 caja 300
1.1.1.1 caja general 300


asi deben presentarse los balances , alguna idea q puedo hacer , recuerden que es solo presentacion , uso fastreport y delphi 6

desde ya mil gracias

hace un tiempo hicimos algo en foxpro
y lo que hacia era ir recursivamente restando valor hasta ver el nivel superiro a la cuenta y asi hasta llegar al nivel superior acumulando los valores pero ahora como q se ma cerrado el cerebro , porque las cuentas no siempre van en orden ejemplo

1 Activo
1.1 activo fijos
1.1.1 caja
100 caja general
__________________
IVAND
Responder Con Cita
  #2  
Antiguo 01-05-2012
Avatar de gatosoft
[gatosoft] gatosoft is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Bogotá, Colombia
Posts: 833
Poder: 22
gatosoft Va camino a la fama
Hola IvanD...

¿¿Que base de datos utilizas???, aunque creo que sin importar cual, debería poderse resolver por SQL la situación asi:

Asumo que tienes dos tablas:

1) Cuentas que debe ser algo como:

PlanDeCuentas:
CodCuenta, Descripción
1 Activo,
1.1 activo fijos
1.1.1 caja
1.1.1.1 caja general

Asumo que debes tener una tabla de asientos o movimientos, algo como:

Movimientos:
Id.Cpbte, Fecha, cuentaMov, Valor
1,2012-04-28,'1.1.1.1', 100,
2,2012-04-29,'1.1.1.1', 200,
3,2012-04-28,'1.1.1.2', 500,

Como las cuentas son strings y manejan dentro de si la jerarquia, puedes hacer una consulta asi:

Código SQL [-]
Select AA.CodCuenta, AA.Descripción, (Select sum(BB.Valor) from Movimientos BB where (BB.cuentaMov like AA.CodCuenta||'%') and (Fecha between :F1 and :F2))
from PlanDeCuentas AA

La clave está en que puedes utilziar una conslta anidada, que traiga siempre la sumatoria de todos los moviemientos que comiencen por la cuenta que llamas...

Puedes probar la conulsta sola en tu tabla de movimientos con:
Código SQL [-]
Select sum(Valor) 
from Movimientos  
where (cuentaMov like '1.1.%') 
and (Fecha between F1 and F2)


este es un ejemplo en SQL Server que te ayuda con el ejercicion

Código SQL [-]
select SUM(valor) from (
select *
from (
select 1 as idcpbte, '1.1.1.1' as cuenta, 100 valor union
select 2 as idcpbte, '1.1.1.1' as cuenta, 200 valor union
select 3 as idcpbte, '2.1.1.1' as cuenta, 500 valor
) as C2
where cuenta like '2.1.%' -- Modifica aqui el valor que quieres probar...
) as C3

Espero que sea lo que buscabas y que te haya servido
Responder Con Cita
  #3  
Antiguo 01-05-2012
Avatar de newtron
[newtron] newtron is offline
Membrillo Premium
 
Registrado: abr 2007
Ubicación: Motril, Granada
Posts: 3.471
Poder: 21
newtron Va camino a la fama
Hola.

Yo en particular lo que hago en mi programa de contabilidad es mantener una tabla de acumulados por cada cuenta de forma de que cada vez que se introduce un asiento en una cuenta se acumula automáticamente mediante triggers en sus cuentas de nivel superior y así tienes disponible el dato para cuando quieras consultarlo lo hagas de forma rápida.

Ten en cuenta de que en una contabilidad cualquiera hacer balances calculando los importes se puede hacer bastante tedioso por lo lento.

Saludos
__________________
Be water my friend.
Responder Con Cita
  #4  
Antiguo 02-05-2012
IVAND IVAND is offline
Miembro
 
Registrado: may 2003
Ubicación: ECUADOR
Posts: 523
Poder: 21
IVAND Va por buen camino
Hola a todos

Newtron puedes por favor ayudarme indicando como haces la tabla acumulada y como lo activas desde los trigger por favor

probare tu metodo amigo gatosoft
__________________
IVAND
Responder Con Cita
  #5  
Antiguo 02-05-2012
Avatar de newtron
[newtron] newtron is offline
Membrillo Premium
 
Registrado: abr 2007
Ubicación: Motril, Granada
Posts: 3.471
Poder: 21
newtron Va camino a la fama
Cita:
Empezado por IVAND Ver Mensaje
Newtron puedes por favor ayudarme indicando como haces la tabla acumulada y como lo activas desde los trigger por favor
Hombre, si lo pides de esa manera no me puedo negar.

Teniendo en cuenta de que las contabilidades se llevan por ejercicios lo que tengo es una tabla con estos campos:

CUENTA
MES
DEBE
HABER

Cada vez que se introduce/modifica/anula un apunte en el fichero de apuntes se dispara un trigger que va a esa tabla y acumula ese importe en la cuenta del apunte y en sus niveles superiores. Logicamente si el registro no existe lo crea y si existe lo suma a lo que hay. Suponiendo que introduces un asiento 1000 euros al debe de la 4300000 contra la cuenta 5700000 en el mes de Enero se crearían los siguientes registros:

Código SQL [-]

CUENTA       MES              DEBE            HABER
--------       ---          --------          --------
4                  01              1000                    0
43                01              1000                    0
430              01               1000                    0
4300             01              1000                    0
4300000        01              1000                    0
5                 01                   0                1000
57                01                  0                1000
570              01                   0                1000
5700             01                  0                1000
5700000        01                  0                1000

Normalmente los balances se suelen pedir acumulados totales o de un mes/trimestre, etc. con lo cual con estos datos puedes emitir de forma rápida un balance entro los meses que te digan sin hacer grandes cálculos y de forma rápida.

De todas formas necesitarás tener la posibilidad de hacer balances entre unas fechas determinadas para lo cual tendrías que tener otro que te lo saque de la manera que te comenta el compañero gatosoft pero este será algo más lento aunque necesario para ocasiones puntuales.

Saludos
__________________
Be water my friend.
Responder Con Cita
  #6  
Antiguo 02-05-2012
IVAND IVAND is offline
Miembro
 
Registrado: may 2003
Ubicación: ECUADOR
Posts: 523
Poder: 21
IVAND Va por buen camino
Muy buen punto newtron voy a tomar esta idea a ver como puedo hacer para adaptarla a mis necesidades , aunque no me has indicado como disparas los triggers y como acumulas a nivel superir las cuentas jejejejeje

Muchas gracias por tu aporte
__________________
IVAND
Responder Con Cita
  #7  
Antiguo 02-05-2012
Avatar de newtron
[newtron] newtron is offline
Membrillo Premium
 
Registrado: abr 2007
Ubicación: Motril, Granada
Posts: 3.471
Poder: 21
newtron Va camino a la fama
Cita:
Empezado por IVAND Ver Mensaje
Muy buen punto newtron voy a tomar esta idea a ver como puedo hacer para adaptarla a mis necesidades , aunque no me has indicado como disparas los triggers y como acumulas a nivel superir las cuentas jejejejeje
Bueno, mucho me temo que en eso no te puedo ayudar mucho porque no usamos la misma base de datos. Si usas firebird haz una búsqueda por trigger y encontrarás ejemplos. Si de todas formas sigues atascado crea un hilo nuevo en el apartado de bases de datos para ver como se crean los triggers.

Saludos
__________________
Be water my friend.
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
Presentación en Barcelona de Delphi XE2 y Builder XE2 neftali2 Noticias 0 28-07-2011 13:30:14
Contabilidad Doméstica - tipo Acoran Money, contabilidad doméstica y gnu cash JXJ Varios 2 02-08-2010 02:51:41
Realizar una presentación en Delphi Peri Varios 8 07-06-2008 17:00:07
Ayuda con consulta | Se complicó el tema hmoner SQL 5 06-05-2005 10:22:36
Presentación del nuevo Delphi marto Noticias 9 30-10-2004 15:00:14


La franja horaria es GMT +2. Ahora son las 17:31:26.


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