Aprende Java Aprende Php Aprende C++ Aprende HTML 5 Aprende JavaScript Aprende JSON Aprende MySQL Aprende SQLServer Aprende Visual Basic 6 Aprende PostgreSQL Aprende SQLite Aprende Redis Aprende Kotlin Aprende XML Aprende Linux VSC Aprende Wordpress Aprende Laravel Aprende VueJS Aprende JQuery Aprende Bootstrap Aprende Netbeans Aprende Android
Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube Sigueme en TikTok Sigueme en Whatsapp
Home / Desarrollo Web / PHP / Compartir conexión de base de datos

Compartir conexión de base de datos

Por jc mouse viernes, mayo 25, 2012

Cuando utilizamos aplicaciones web con conexión a base de datos MYSQL, se suele crear una clase que gestione la interacción MySQL/PHP,  y esta instanciarla cada vez que se requiera hacer uso de ella, sin embargo cuando tenemos que realizar multiples conexiones al servidor esto no es muy eficiente, es decir, si tenemos una clase conexión como la siguiente:

CLASE: db_A.class.php

<?php
class database {

    var $localhost = "localhost";    
    var $usuario = "root"   ;
    var $password = "root";
    var $database = "db123"; 
    private $conexion = NULL;

    /* METODO PARA CONECTAR CON LA BASE DE DATOS*/
 public function __construct()
 {
  if(!isset($this->conexion)){
     $this->conexion = (mysql_connect($this->localhost, $this->usuario,$this->password)) or die(mysql_error() );
     if ($this->conexion)  echo 'Conexión a base de datos establecida<br/>';
    mysql_select_db($this->database , $this->conexion) or die(mysql_error());      
  }
 } 

 /* METODO PARA REALIZAR UNA CONSULTA */
 public function consulta()
 {
  $q=" SELECT * FROM estudiante ORDER BY rand() LIMIT 1";
   $resultado = mysql_query($q,$this->conexion);
    if(!$resultado){
     echo 'MySQL Error: ' . mysql_error();
     exit;
    }
  while ($fila = mysql_fetch_assoc($resultado)) {
    echo 'Registro: '.$fila["id"].' | '.$fila["nombre"].' | '.$fila["edad"].'<br/>';
  }
 } 

}
?>

Para este ejemplo utilizamos una base de datos «db123» la cual tiene la siguiente tabla:

CREATE TABLE estudiante (
  id int(2) NOT NULL auto_increment,
  nombre varchar(32) NOT NULL,
  edad varchar(32) NOT NULL,
  PRIMARY KEY  (id)
) 

INSERT INTO estudiante VALUES (1, 'Pedro Picapiedra', '34');
INSERT INTO estudiante VALUES (2, 'Pablo Marmol', '45');
INSERT INTO estudiante VALUES (3, 'Bartolomeo', '22');
INSERT INTO estudiante VALUES (4, 'Moe', '37');

Cuando implementamos nuestra clase de conexion «db_A.class.php» , hacemos lo siguiente:

<?php
require_once 'db_A.class.php';

$db1 = new database();
$db1->consulta();

$db2 = new database();
$db2->consulta();

$db3 = new database();
$db3->consulta();

?>

Para cada objeto creamos una instancia a la clase «database» y ejecutamos una consulta, esto nos da como resultado:

Conexión a base de datos establecida
Registro: 4 | Moe | 37
Conexión a base de datos establecida
Registro: 2 | Pablo Marmol | 45
Conexión a base de datos establecida
Registro: 4 | Moe | 37

Como se puede ver, cada que se crea una instancia de clase, se realiza una nueva conexión a la base de datos, esto si bien no esta mal, no es muy eficiente cuando tenemos múltiples tareas que realizar con el servidor, para optimizar nuestra clase de conexión, es mucho mejor hacer uso de las propiedades estáticas (STATIC), esto nos permite compartir una conexión al servidor entre varios objetos de una clase, por ejemplo, modificamos nuestra clase de conexión ahora llamada db_B.class.php, de la siguiente manera:

<?php
class database {

    var $localhost = "localhost";    
    var $usuario = "root"   ;
    var $password = "root";
    var $database = "db123"; 
    private static $conexion=NULL;

    /* METODO PARA CONECTAR CON LA BASE DE DATOS*/
 public function __construct()
 {
  if(!isset(self::$conexion))    
    {
        self::$conexion = (mysql_connect($this->localhost, $this->usuario,$this->password)) or die(mysql_error() );
        if (self::$conexion)  echo 'Conexión a base de datos establecida<br/>';
       mysql_select_db($this->database , self::$conexion) or die(mysql_error());      
    }
 } 

 /* METODO PARA REALIZAR UNA CONSULTA */
 public function consulta()
 {
  $q=" SELECT * FROM estudiante ORDER BY rand() LIMIT 1";
   $resultado = mysql_query($q,self::$conexion);
    if(!$resultado){
     echo 'MySQL Error: ' . mysql_error();
     exit;
    }
  while ($fila = mysql_fetch_assoc($resultado)) {
    echo 'Registro: '.$fila["id"].' | '.$fila["nombre"].' | '.$fila["edad"].'<br/><br/>';
  }
 } 

}
?>

Modificamos nuestra variable $conexion convirtiendo esta en STATIC, la forma de referirnos a ella en nuestra clase es utilizando la instrucción SELF seguido de dos puntos «self::variable_estática«, el resto del código se mantiene igual.

<?php
require_once 'db_B.class.php';

$db1 = new database();
$db1->consulta();

$db2 = new database();
$db2->consulta();

$db3 = new database();
$db3->consulta();

?>

ejecutamos el código:

Conexión a base de datos establecida
Registro: 2 | Pablo Marmol | 45

Registro: 1 | Pedro Picapiedra | 34

Registro: 1 | Pedro Picapiedra | 34

Como se ve en el gráfico superior, solo se realiza una conexión al servidor aunque creamos tres instancias a nuestra clase de conexión como en el primer ejemplo, la variable STATIC nos permite compartir la conexión entre las clases y así evita crear nuevas conexiones innecesarias.

Archivos utilizados en este post, AQUI

Tags

Artículos similares

Personalizar iconos de un JTree

JTree cuenta con métodos que nos permiten cambiar los iconos de cada nodo según su estado, sin embargo a veces esto no e[...]

Personalizar JTable: Problema resuelto

En este post se da respuesta a una pregunta realizada por facebook. El problema dice así: Se quiere personalizar un JTab[...]

Pruebas funcionales con AssertJ Swing

AssertJ Swing es una biblioteca para Java que proporciona una interfaz fluida para la realización automatizada de prueba[...]

Primeros pasos con JavaFX

¿Qué es javaFX? JavaFX es una familia de productos y tecnologías de Sun Microsystems, adquirida por Oracle Corporation,[...]

Imprimir Swing

Java Printing nos permite hacer uso de las impresoras del sistema para, valga la redundancia 🙂 imprimir los gráficos de[...]

Puzzle en Visual Basic [Código Fuente]

Rompecabezas 3×3 realizado en Visual Basic .NET, lo que se hizo fue una migración de un proyecto hecho en java (pue[...]