Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Duda de migracion a mysqli en php

Estas en el tema de Duda de migracion a mysqli en php en el foro de PHP en Foros del Web. Bueno como ya se sabe el mysql de php esta terminando su ciclo de vida por lo que empece a migrar mi framework a mysqli, ...
  #1 (permalink)  
Antiguo 07/02/2013, 14:37
 
Fecha de Ingreso: febrero-2009
Ubicación: Cusco - Peru
Mensajes: 142
Antigüedad: 15 años, 3 meses
Puntos: 0
Duda de migracion a mysqli en php

Bueno como ya se sabe el mysql de php esta terminando su ciclo de vida por lo que empece a migrar mi framework a mysqli, al principio en la prueba todo bien, pero tengo la siguiente duda:

con mysql yo hacia lo siguiente:

1.- Abría la conexión (esto llamando a una clase Conexion.php cuyo constructor realizaba la conexion y devolvia el link, con mas cosas obviamente, controlando errores y todo, pero lo principal era que abria una conexion ):

$link = mysql_connect(host,user,psw);

2.- luego hacia un include a una clase de Consulta.php, la cual utilizando la conexion abierta anteriormente por la clase conexion.php, resolvía todos los Querys que necesitaba, y por consiguiente yo podía llamar "n" veces a la clase Consulta y trabajar sobre ellas porque ya tenia una conexión abierta disponible, sin necesidad de usar el "$link" retornado por la clase Conexion.

en conclucion 1 conexion para varios Querys

ahora veo con mysqli

1.- Que para cada Query que necesite yo ejecutar necesito del "$link" que me devuelve la clase conexion, cosa que no se como tratarlo pòrque muchas de las consultas que realizo, por el hecho de ser POO, puedo requerirla dentro de un metodo de otra clase y estar jalando o arrastrando la variable link se me hace engorroso.
2.- trate otro método, que dentro de mi clase Consulta yo realice la conexión a la BD, lo cual si bien es practico, porque solo tengo que llamar a mi clase Consulta y esta se encarga de hacer la conexión y resolver los Querys que yo necesite, pero aquí veo otro problema que si dentro de una operación yo requiera realizar varios Querys y por cada uno de ellos, yo llame a una clase consulta me abrirá una conexión diferente y si fuera un bucle de cientos de datos que requiera ingresar me abriría cientos de conexiones, entonces también le veo un gran problema.

En conclusion 1 conexion para 1 Query, 1000 conexiones para 1000 querys

Cual seria la forma de realizar la migracion de mi clases conexion y consulta a la forma de mysqli?, se puede realizar una sola conexion con mysqli y trabajar sobre ella para varios Querys??

Talvez la respuesta sea sencilla pero creo que estoy haciendo bolas o talvez si tenga razon, la verdad que no se, hechenme una mano con esto pes.

Salu2.
  #2 (permalink)  
Antiguo 07/02/2013, 14:45
Avatar de maycolalvarez
Colaborador
 
Fecha de Ingreso: julio-2008
Ubicación: Caracas
Mensajes: 12.120
Antigüedad: 15 años, 9 meses
Puntos: 1532
Respuesta: Duda de migracion a mysqli en php

de hecho se recomendaba usar el $link (o resource_id) también para cada consulta con la obsoleta librería de mysql.

con POO la cosa cambia, porque si tienes un objeto conexión se supone que utilices el objeto para hacer las consultas porque eso de tener una conexión implícita acarrea problemas, por ejemplo cuando necesitas hacer transacciones independientes y demás.

¿te resulta engorroso pasar la instancia de la conexión?: bueno para ello puedes implementar patrones de diseño como Singleton que te permiten tener una sola instancia, obtendrías la instancia de la forma:

MyConnectionDBClass::getInstance();

(puedes conseguir un ejemplo de singleton php buscando en la red)

claro, singleton incluso ya se considera poco recomendable, algunos FW como Symfony2 utilizan un avanzado sistema de Inyección por Dependencias, pero creo que en tu caso no consideraría llegar a tanto, primero prueba con singleton y luego avanzas al respecto, en otro proyecto.

Por otro lado te recomendaría usar PDO en vez de MySQLi, así puedes expandirte a otros SDBMS, luego usar ORM's como Doctrine2 o su capa DBAL.
__________________
¡Por favor!: usa el highlight para mostrar código
El que busca, encuentra...
  #3 (permalink)  
Antiguo 07/02/2013, 14:47
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 15 años, 8 meses
Puntos: 2237
Respuesta: Duda de migracion a mysqli en php

No sé cómo llegaste a esa conclusión, pero la cosa no es así.

1- Conectas a mysqli, orientado a objetos, porque por procedimiento ya es obsoleto
2- Ejecutas todas las consultas que sean necesarias $result = $mysqli->query(/* consulta */);
3- Al final cierras la conexión, aunque no es requisito

Un ejemplo: http://www.php.net/manual/es/mysqli....p#example-1731

La conexión puede ser una propiedad de tu controlador primario y accedes a ella por: $controlador->mysqli o, si es propiedad estática por: claseControlador::$mysqli
__________________
- León, Guanajuato
- GV-Foto
  #4 (permalink)  
Antiguo 07/02/2013, 16:20
 
Fecha de Ingreso: febrero-2009
Ubicación: Cusco - Peru
Mensajes: 142
Antigüedad: 15 años, 3 meses
Puntos: 0
Respuesta: Duda de migracion a mysqli en php

Gracias a los 2, realice como me indicaron una propiedad dentro de mi controlador y ahi almacene el link de conexión y ahora prácticamente no tengo que hacen grandes cambios solo en mi clase Consulta que la manejare con POO, y si creo q empezare a ver el PDO por su comentario y por lo que vi en el manual de php.

Muchas Gracias.

Etiquetas: mysql, mysqli
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 01:56.