(PHP 5, PHP 7)
mysqli::__construct -- mysqli_connect — Abre una nueva conexión al servidor de MySQL
Estilo orientado a objetos
$host
= ini_get("mysqli.default_host")
[, string $username
= ini_get("mysqli.default_user")
[, string $passwd
= ini_get("mysqli.default_pw")
[, string $dbname
= ""
[, int $port
= ini_get("mysqli.default_port")
[, string $socket
= ini_get("mysqli.default_socket")
]]]]]] )Estilo por procedimientos
$host
= ini_get("mysqli.default_host")
[, string $username
= ini_get("mysqli.default_user")
[, string $passwd
= ini_get("mysqli.default_pw")
[, string $dbname
= ""
[, int $port
= ini_get("mysqli.default_port")
[, string $socket
= ini_get("mysqli.default_socket")
]]]]]] ) : mysqliAbre una conexión al Servidor de MySQL que está en ejecución.
host
Puede ser o un nombre de host o una dirección IP. Pasando el valor NULL
o la cadena "localhost" a este parámetro, se asumirá el host
local. Cuando es posible, se usarán tuberías en lugar del protocolo
TCP/IP.
Anteponer p: al host, abre una conexión persistente. mysqli_change_user() es automáticamente llamado en conexiones abiertas desde la caché de conexiones.
username
El nombre de usuario de MySQL.
passwd
Si no se proporciona o es NULL
, el servidor MySQL intentará autentificar
el usuario solo con aquellos registros de usuarios que no tienen contraseña. Esto
permite que un nombre de usuario ser usado con diferentes permisos (dependiendo de
si se proporciona una contraseña o no).
dbname
Si se proporcioina, especificará la base de datos prederminada a usar cuando se realizan consultas.
port
Especifica el número al que intentar conectar al servidor de MySQL.
socket
Especifica el socket o la tubería con nombre que debería usarse.
Nota:
Especificar el parámetro
socket
no determinará explicitamente el tipo de conexión a utilizar cuando se conecte al servidor MySQL. El modo de realizar la conexión a la base de datos MySQL es determinado por el parámetrohost
.
Devuelve un objeto que representa la conexión al servidor MySQL.
Versión | Descripción |
---|---|
5.3.0 | Se añadió la capacidad de conexiones persistentes. |
Ejemplo #1 Ejemplo de mysqli::__construct()
Estilo orientado a objetos
<?php
$mysqli = new mysqli('localhost', 'mi_usuario', 'mi_contraseña', 'mi_bd');
/*
* Esta es la forma OO "oficial" de hacerlo,
* AUNQUE $connect_error estaba averiado hasta PHP 5.2.9 y 5.3.0.
*/
if ($mysqli->connect_error) {
die('Error de Conexión (' . $mysqli->connect_errno . ') '
. $mysqli->connect_error);
}
/*
* Use esto en lugar de $connect_error si necesita asegurarse
* de la compatibilidad con versiones de PHP anteriores a 5.2.9 y 5.3.0.
*/
if (mysqli_connect_error()) {
die('Error de Conexión (' . mysqli_connect_errno() . ') '
. mysqli_connect_error());
}
echo 'Éxito... ' . $mysqli->host_info . "\n";
$mysqli->close();
?>
Estilo orientado a objetos cuando se extiende la clase mysqli
<?php
class foo_mysqli extends mysqli {
public function __construct($host, $usuario, $contraseña, $bd) {
parent::__construct($host, $usuario, $contraseña, $bd);
if (mysqli_connect_error()) {
die('Error de Conexión (' . mysqli_connect_errno() . ') '
. mysqli_connect_error());
}
}
}
$bd = new foo_mysqli('localhost', 'mi_usuario', 'mi_contraseña', 'mi_bd');
echo 'Éxito... ' . $bd->host_info . "\n";
$bd->close();
?>
Estilo por procedimientos
<?php
$enlace = mysqli_connect('localhost', 'mi_usuario', 'mi_contraseña', 'mi_bd');
if (!$enlace) {
die('Error de Conexión (' . mysqli_connect_errno() . ') '
. mysqli_connect_error());
}
echo 'Éxito... ' . mysqli_get_host_info($enlace) . "\n";
mysqli_close($enlace);
?>
El resultado de los ejemplos sería:
Éxito... MySQL host info: localhost via TCP/IP
Nota:
MySQLnd siempre utiliza el juego de caracteres de idioma predeterminado. El juego de caracteres se envía en la autentificación/acuerdo que se produce durante la conexión, que utilizará mysqlnd.
Libmysqlclient utiliza el juego de caracteres predeterminado definido en my.cnf o se puede establecer llamando mysqli_options() antes de user mysqli_real_connect(), pero después de mysqli_init().
Nota:
Sólo para la sintaxis OO: Si una conexión falla se devuelve un objeto. Para comprobar si la conexión falló, use la función mysqli_connect_error() o la propiedad mysqli->connect_error como en los ejemplos anteriores.
Nota:
Si es necesario establecer las opciones, tales como el tiempo de espera de conexión, se debe utilizar mysqli_real_connect() en su lugar.
Nota:
Llamar al constructor sin parámetros es lo mismo que llamar a la función mysqli_init().
Nota:
El error "Can't create TCP/IP socket (10106)" normalmente significa que la directiva de configuración variables_order no contiene el carácter E. En Windows, si el entorno no es copiado, la variable de entorno SYSTEMROOT no estará disponible y PHP tendrá problemas al cargar Winsock.