Foros del Web » Programando para Internet » PHP »

Clase para sesion mysql

Estas en el tema de Clase para sesion mysql en el foro de PHP en Foros del Web. Saludos amigos foreros, estaba intentando usar este codigo: Código: 1 <?php 2 3 require_once( 'BaseDeDatos.class.php' ) 4 5 class Persistente { 6 var $id; 7 ...
  #1 (permalink)  
Antiguo 29/12/2011, 02:00
 
Fecha de Ingreso: julio-2010
Mensajes: 158
Antigüedad: 14 años, 4 meses
Puntos: 3
Clase para sesion mysql

Saludos amigos foreros, estaba intentando usar este codigo:

Código:
1  
<?php 
2  
3  require_once( 'BaseDeDatos.class.php' )
4  
5  class Persistente {
6     var $id;
7     var $tabla;
8     var $orden;
9  
10     var $sql_one = "SELECT * FROM %s WHERE id = %s ";
11     var $sql_all = "SELECT * FROM %s ORDER BY %s ASC";
12  
13     function getId( $id ){
14        $sql = sprintf( $this->sql_one, $this->tabla, $id );
15  
16        $bd = new BaseDeDatos();
17        $datos = $bd->traerTodo( $sql );
18        $this->cargarDatos( $datos );
19     }
20     function cargarDatos( $datos ){
21        foreach( $datos as $key => $it ){
22           $this->$key = $it;
23        }
24     }
25     function getAll(){
26        $sql = sprintf( $this->sql_all, $this->tabla, $this->orden );
27  
28        $bd = new BaseDeDatos();
29        $datos = $bd->traerTodo( $sql );
30        return $datos
31     }
32  } 
33  
34  ?>
Pero tengo un problema al no saber que debo poner en el archivo BaseDeDatos.class.php pues no se como llamar la sesion de mysql con clases cuando lo hago con funciones lo hago asi:

Código:
function BaseDeDatos() 
{ 
   if (!($link=mysql_connect("localhost","usuario","Password"))) 
   { 
      echo "Error conectando a la base de datos."; 
      exit(); 
   } 
   if (!mysql_select_db("base_datos",$link)) 
   { 
      echo "Error seleccionando la base de datos."; 
      exit(); 
   } 
   return $link; 
}
Pero si lo pongo como clase no me funciona:

Código:
class BaseDeDatos
{ 
   if (!($link=mysql_connect("localhost","usuario","Password"))) 
   { 
      echo "Error conectando a la base de datos."; 
      exit(); 
   } 
   if (!mysql_select_db("base_datos",$link)) 
   { 
      echo "Error seleccionando la base de datos."; 
      exit(); 
   } 
   return $link; 
}
Alguna idea de como puedo hacer funcionar esto?
  #2 (permalink)  
Antiguo 29/12/2011, 04:20
Avatar de Karmac  
Fecha de Ingreso: agosto-2011
Ubicación: Bilbao
Mensajes: 196
Antigüedad: 13 años, 3 meses
Puntos: 34
Respuesta: Clase para sesion mysql

Todo eso tiene que estar en una función.
Un ejemplo:
Código PHP:
<?php
class DataBase
{
    private 
$conn;
    
    public function 
connect$localhost$username$password$database )
    {
        
$this->conn mysql_connect$localhost$username$password );
        
mysql_select_db$database$this->conn );
    }
}
?>
Nota: añadele los errores al código, es solamente un ejemplo.

De todos modos te aconsejaría que utilizases MySQLi, un objeto ya incluido en PHP que sustituye a las funciones comúnes. http://php.net/manual/en/book.mysqli.php

Saludos.

Etiquetas: clase, mysql, sql, tabla, usuarios
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 21:17.