Foros del Web » Programando para Internet » PHP »

PHP OO Problema con clase, SELECT, MYSQLi

Estas en el tema de Problema con clase, SELECT, MYSQLi en el foro de PHP en Foros del Web. Buenas Tardes comunidad, Desde hace mucho rato que tengo un problema con mi clase, es bien sencilla. El principio de mi clase: Código PHP: public  ...
  #1 (permalink)  
Antiguo 10/04/2014, 13:51
 
Fecha de Ingreso: noviembre-2012
Ubicación: Tegucigalpa
Mensajes: 94
Antigüedad: 11 años, 5 meses
Puntos: 0
Problema con clase, SELECT, MYSQLi

Buenas Tardes comunidad,

Desde hace mucho rato que tengo un problema con mi clase, es bien sencilla.

El principio de mi clase:
Código PHP:
public $production;
    
    public function 
setProduction($x){
        
$this->production $x;
    }

    public function 
getProduction(){
        return 
$this->production;
    } 
Esta es la función en donde se debería de hacer la consulta y recolectar los registros de la base de datos.

Código PHP:
public function getProductionList()
    {
        if (isset(
$_SERVER['dbHost']) && ($_SERVER['dbUsr']) && ($_SERVER['dbPsw']) && ($_SERVER['db'])) {
            
$root $_SERVER['DOCUMENT_ROOT'];
        }else {
            
$root $_SERVER['DOCUMENT_ROOT']."/";
        }
        include (
$root."classes/connect.php");
    
        
// Create records array
        
$records = array();
        
        
// Execute query
        
if($results $db->query("CALL wm.getProduction();")){
            if(
$results->num_rows){
                while(
$row $results->fetch_object()){
                    
$records[] = $row;
                }
                
$results->free();
                
$this->setProduction($records);
            }
        }
        
$db->next_result(); // close query and prepare for next one.
    
// End Function. 
En esta función debería de recorrer todo el arreglo de la función anterior
Código PHP:
<?php
public function drawTable()
    { 
        
        
$records $this->getProduction(); ?>
        <table class="table table-striped table-hover">
            <thead>
                <tr>
                    <th>Production ID</th>
                    <th>Post Date</th>
                    <th>Vehicle ID</th>
                    <th>Weight</th>
                    <th>Cost Type</th>
                    <th>Total Cost</th>
                </tr>
            </thead>
            <tbody> <?

        
if(!count($records)){ ?>
        <tr valign="middle">
            <td colspan="2" align="center"> <? echo 'No data available for this view'?> </td>
        </tr><?pho
            
}else{                
            foreach(
$records as $r){?>
        <tr>
            <td><?php echo $r->production?></td>
            <td><?php echo $r->post?></td>
            <td><?php echo $r->vehicle?></td>
            <td><?php echo $r->weight?></td>
            <td><?php echo $r->cost?></td>
            <td><?php echo $r->costTwo?></td>
        </tr>
            <?php } } ?>



            </tbody>
        </table>
<?php
 
}
?>
Entonces cuando la mando a llamar drawTable, en mi documento principal me sale el siguiente error:
Código:
Notice: Undefined variable: r in C:\xampp\htdocs\classes\employees.php on line 60
Comprobe que el procedimiento de la base de datos funcionará correctamente, que la tabla estuviera llena, comprobe todo. Lo que no entiendo es porque no me toma los valores $R cuando en realidad la consulta si se realiza bien.

No se, si me explique bien, espero de su ayuda. De verdad se los agradeceré de corazón.
  #2 (permalink)  
Antiguo 11/04/2014, 04:48
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Sabadell
Mensajes: 4.897
Antigüedad: 16 años, 1 mes
Puntos: 574
Respuesta: Problema con clase, SELECT, MYSQLi

Estaria bien saber que linea es la linea 60.

$R y $r no son lo mismo

Código PHP:
Ver original
  1. <? echo 'No data available for this view'; ?>
deberia ser

Código PHP:
Ver original
  1. <?php echo 'No data available for this view'; ?>


Tienes la linea "</tr><?pho " no se si es un problema de transcripción al post....

Corrige y cuentanos....


A parte

<?php echo $r->production?>

yo uso la sintaxis

<?php echo $r["production"]; ?>
__________________
Quim
--------------------------------------------------
Ayudar a ayudar es una buena práctica!!! Y da buenos resultados.
  #3 (permalink)  
Antiguo 11/04/2014, 09:13
 
Fecha de Ingreso: abril-2014
Ubicación: Canarias!
Mensajes: 150
Antigüedad: 10 años
Puntos: 10
Respuesta: Problema con clase, SELECT, MYSQLi

Cita:
Iniciado por quimfv Ver Mensaje

A parte

<?php echo $r->production?>

yo uso la sintaxis

<?php echo $r["production"]; ?>
Cuidado!

Este es para hacer referencia a un objeto:
<?php echo $r->production?>

Este es para hacer referencia a un array
<?php echo $r["production"]; ?>

El valor de $r es un objecto, en el segundo archivo, cuando hace la consulta a la base de datos, los guarda mediante un fetch_object.

Por tanto está bien esa parte.

Pero si, el comentario encima tiene razón, nos podrias indicar cual es la linea 60 del archivo empleados?
  #4 (permalink)  
Antiguo 11/04/2014, 10:02
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Sabadell
Mensajes: 4.897
Antigüedad: 16 años, 1 mes
Puntos: 574
Respuesta: Problema con clase, SELECT, MYSQLi

Cierto lo que dice @Qazser

Pero si despejas las otras dudas sabremos por donde vamos.

Código MySQL:
Ver original
  1. CALL wm.getProduction();

Nos dice muy poco de que query se esta ejecutando, entiendo que la tienes en el SP....
__________________
Quim
--------------------------------------------------
Ayudar a ayudar es una buena práctica!!! Y da buenos resultados.

Etiquetas: clase, mysqli, registro, select, tabla, variable
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 17:39.