Foros del Web » Programando para Internet » PHP »

Funciones de Calculo

Estas en el tema de Funciones de Calculo en el foro de PHP en Foros del Web. Hola amigos, tengo un percance y me gustaria saber si me pueden ayudar. Bueno mas bien es una duda, este es mi codigo: Código PHP: ...
  #1 (permalink)  
Antiguo 30/07/2010, 09:30
 
Fecha de Ingreso: julio-2010
Mensajes: 19
Antigüedad: 13 años, 9 meses
Puntos: 0
Sonrisa Funciones de Calculo

Hola amigos, tengo un percance y me gustaria saber si me pueden ayudar.

Bueno mas bien es una duda, este es mi codigo:
Código PHP:
<?php
function afp($patrono,$empleado,$salario,$max,$min){
    var 
$patrono;
    var 
$empleado;
    var 
$resultado1_afp1;
    var 
$resultado2_afp2;
    if (
$salario >= $max){
        
$resultado_afp1=$salario*$patrono;
        
$resultado_afp2=$salario*$empleado;
    } else{
        
$resultado_afp1="";$resultado_afp2="";
    }
    
///resultados obtenidos en variables:////////////////////////////////////////////
    //$resultado1_afp1;
    //$resultado2_afp2;
}
function 
renta($patrono,$empleado,$salario,$max,$min){
    var 
$patrono;
    var 
$empleado;
}
function 
isss($patrono,$empleado,$salario,$max,$min){
    var 
$patrono;
    var 
$empleado;
    var 
$patrono;
    var 
$empleado;
    var 
$resultado1_isss1;
    var 
$resultado2_isss2;
    if (
$salario >= $max){
        
$resultado1_isss1=$max*$patrono;
        
$resultado2_isss2=$max*$empleado;
    } else{
        
$resultado1_isss1=$salario*$patrono;
        
$resultado1_isss1=$salario*$empleado;
        }
    
///resultados obtenidos en variables:////////////////////////////////////////////
    //$resultado1_isss1;
    //$resultado2_isss2;
}


//isss emp 3%
//isss pat 7.5%
//isss max 685.7
//afp-emp 6.25%
//afp-pat 6.75%
//afp-min 207.60
//afp-max 5354.52
//renta
?>
Esta es la tabla:
Código MySQL:
Ver original
  1. SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
  2.  
  3. --
  4. -- Base de datos: `sistemas`
  5. --
  6.  
  7. -- --------------------------------------------------------
  8.  
  9. --
  10. -- Estructura de tabla para la tabla `configuracion`
  11. --
  12.  
  13. CREATE TABLE `configuracion` (
  14.   `id_configuracion` int(4) NOT NULL auto_increment,
  15.   `nombre` varchar(255) NOT NULL,
  16.   `valor` float(10,2) NOT NULL,
  17.   PRIMARY KEY  (`id_configuracion`)
  18. ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COMMENT='tabla de configuracion para planilla' AUTO_INCREMENT=9 ;
  19.  
  20. --
  21. -- Volcar la base de datos para la tabla `configuracion`
  22. --
  23.  
  24. INSERT INTO `configuracion` VALUES (1, 'isss-empleado', 3.00);
  25. INSERT INTO `configuracion` VALUES (2, 'isss-patrono', 7.50);
  26. INSERT INTO `configuracion` VALUES (3, 'isss-salmax', 685.71);
  27. INSERT INTO `configuracion` VALUES (4, 'afp-empleado', 6.25);
  28. INSERT INTO `configuracion` VALUES (5, 'afp-patrono', 6.75);
  29. INSERT INTO `configuracion` VALUES (6, 'afp-min', 207.60);
  30. INSERT INTO `configuracion` VALUES (7, 'afp-max', 5354.52);
  31. INSERT INTO `configuracion` VALUES (8, 'iva', 13.00);


La cuestion, es que yo tengo una tabla aparte para los empleados, que es esta:
Código SQL:
Ver original
  1. --
  2. -- Base de datos: `sistemas`
  3. --
  4.  
  5. -- --------------------------------------------------------
  6.  
  7. --
  8. -- Estructura de tabla para la tabla `empleados`
  9. --
  10.  
  11. CREATE TABLE `empleados` (
  12.   `id` INT(4) NOT NULL AUTO_INCREMENT,
  13.   `nombre` VARCHAR(50) NOT NULL,
  14.   `apellido` VARCHAR(50) NOT NULL,
  15.   `salario` FLOAT(10,2) NOT NULL,
  16.   `dui` VARCHAR(11) NOT NULL,
  17.   `afp` VARCHAR(50) NOT NULL,
  18.   `isss` VARCHAR(50) NOT NULL,
  19.   `nit` VARCHAR(18) NOT NULL,
  20.   KEY `id` (`id`)
  21. ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
  22.  
  23. --
  24. --
  25. --

Ahora bien, mi duda es... Si me podrian orientar con respecto a la cadena, que yo debo llamar para que haga los calculos y luego mostrarlos en la tabla.


Estas son las que tengo para ingresar y actualizar los datos de un empleado:

Código PHP:
    function insertar($campos){
        if(
$this->con->conectar()==true){
            
//print_r($campos);
            //echo "INSERT INTO empleados (nombre, apellido, salario, dui, afp, isss, nit) VALUES ('".$campos[0]."', '".$campos[1]."','".$campos[2]."','".$campos[3]."','".$campos[4]."','".$campos[5]."','".$campos[6]."')");
            
return mysql_query("INSERT INTO empleados (nombre, apellido, salario, dui, afp, isss, nit) VALUES ('".$campos[0]."', '".$campos[1]."','".$campos[2]."','".$campos[3]."','".$campos[4]."','".$campos[5]."','".$campos[6]."')");
        }
    }
    
    function 
actualizar($campos,$id){
        if(
$this->con->conectar()==true){
            
//print_r($campos);
            
return mysql_query("UPDATE empleados SET nombre = '".$campos[0]."', apellido = '".$campos[1]."', salario = '".$campos[2]."', dui = '".$campos[3]."', afp = '".$campos[4]."', isss = '".$campos[5]."', nit = '".$campos[6]."' WHERE id = ".$id);
        }
    } 
Ahora, solo me falta las de hacer las funciones en base al salario del empleado para que me los muestre en la tabla... La cuestion es que todavia no me hago a la idea como... Si serian tan amables de hecharme una mano?

Desde ya, gracias.

EDITO: Explico un poco mas, veamos... Lo que quiero, es, agregar una caja -ya se como- en esta caja, quiero que aparezcan los descuentos que les puse arriba, basados en el salario... Me explico? Es decir, yo lo que quiero es que la funcion AFP, me haga dos selecciones, que elija todos los datos de la tabla configuraciones, y que me elija los datos del empleado -salario- de la base de datos de empleado.

Y es que precisamente lo que no se hacer es el query, porque no encuentro la logica... Si alguien me pudise ayudar? o dar una mano?

Última edición por dumpmail; 30/07/2010 a las 11:28

Etiquetas: calculo, funciones
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 06:50.