(PHP 5, PHP 7, PHP 8)
mysqli::__construct -- mysqli::connect -- mysqli_connect — Ouvre une connexion à un serveur MySQL
Style orienté objet
$hostname
= ini_get("mysqli.default_host"),$username
= ini_get("mysqli.default_user"),$password
= ini_get("mysqli.default_pw"),$database
= "",$port
= ini_get("mysqli.default_port"),$socket
= ini_get("mysqli.default_socket")$hostname
= ini_get("mysqli.default_host"),$username
= ini_get("mysqli.default_user"),$password
= ini_get("mysqli.default_pw"),$database
= "",$port
= ini_get("mysqli.default_port"),$socket
= ini_get("mysqli.default_socket")Style procédural
$hostname
= ini_get("mysqli.default_host"),$username
= ini_get("mysqli.default_user"),$password
= ini_get("mysqli.default_pw"),$database
= "",$port
= ini_get("mysqli.default_port"),$socket
= ini_get("mysqli.default_socket")Ouvre une connexion au serveur MySQL.
hostname
Peut être un nom d'hôte ou une adresse IP.
L'hôte local est présumé si la valeur null
ou la chaîne "localhost"
est passée à ce paramètre.
Si possible, les pipes seront utilisé à la place du protocole TCP/IP.
Le protocol TCP/IP est utilisé si un nom d'hôte et numéro de port sont
fournis ensemble, par exemple localhost:3308
.
Préfixer l'hôte par p:
ouvre une connexion persistante
mysqli_change_user() est automatiquement appelé
sur les connexions qui sont utilisées dans le pool de connexions.
username
Le nom d'utilisateur MySQL.
password
Si le mot de passe n'est pas indiqué (la valeur null
est passée),
le serveur MySQL essaiera d'identifier l'utilisateur en étudiant que les
enregistrements où les utilisateurs n'ont pas de mot de passe. Cela permet
à un utilisateur de jouir de plusieurs permissions (selon qu'un mot de passe
est fournit ou non).
database
Si fourni, spécifiera la base de données par défaut à utiliser lors de l'exécution de requêtes.
port
Spécifie le numéro du port pour la connexion au serveur MySQL.
socket
Spécifie le socket ou le nom du tunnel à utiliser.
Note:
Spécifier le paramètre
socket
ne déterminera pas explicitement le type de connexion qui sera utilisé lors de la connexion au serveur MySQL. Cela est déterminé par le paramètrehostname
.
mysqli::__construct() retourne toujours un objet qui représente la connexion au serveur MySQL, peu importe que celle-ci ait réussi ou non.
mysqli_connect() retourne un objet qui représente la connexion au serveur MySQL,
ou false
si une erreur survient.
mysqli::connect() retourne null
en cas de succès ou false
si une erreur survient.
Si le rapport d'erreurs mysqli est activé (MYSQLI_REPORT_ERROR
) et que l'opération demandée échoue,
un avertissement est généré. Si, en plus, le mode est défini sur MYSQLI_REPORT_STRICT
,
une mysqli_sql_exception est lancée à la place.
Exemple #1 Exemple mysqli::__construct()
Style orienté objet
<?php
/* Vous devriez toujours activer le rapport d'erreur pour mysqli avant une tentative de connexion */
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$mysqli = new mysqli('localhost', 'my_user', 'my_password', 'my_db');
/* Définir le jeu de caractère désiré après avoir établie une connexion */
$mysqli->set_charset('utf8mb4');
printf("Success... %s\n", $mysqli->host_info);
Style procédural
<?php
/* Vous devriez toujours activer le rapport d'erreur pour mysqli avant une tentative de connexion */
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$mysqli = mysqli_connect('localhost', 'my_user', 'my_password', 'my_db');
/* Définir le jeu de caractère désiré après avoir établie une connexion */
mysqli_set_charset($mysqli, 'utf8mb4');
printf("Success... %s\n", mysqli_get_host_info($mysqli));
Les exemples ci-dessus vont afficher quelque chose de similaire à :
Success... localhost via TCP/IP
Exemple #2 Étendre la classe mysqli
<?php
class FooMysqli extends mysqli {
public function __construct($host, $user, $pass, $db, $port, $socket, $charset) {
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
parent::__construct($host, $user, $pass, $db, $port, $socket);
$this->set_charset($charset);
}
}
$db = new FooMysqli('localhost', 'my_user', 'my_password', 'my_db', 3306, null, 'utf8mb4');
Exemple #3 Gestion d'erreur manuelle
Si le rapport d'erreur est désactivé, le développeur est responsable pour vérifier et gérer les échecs
Style orienté objet
<?php
error_reporting(0);
mysqli_report(MYSQLI_REPORT_OFF);
$mysqli = new mysqli('localhost', 'my_user', 'my_password', 'my_db');
if ($mysqli->connect_errno) {
throw new RuntimeException('mysqli connection error: ' . $mysqli->connect_error);
}
/* Définir le jeu de caractère désiré après avoir établie une connexion */
$mysqli->set_charset('utf8mb4');
if ($mysqli->errno) {
throw new RuntimeException('mysqli error: ' . $mysqli->error);
}
Style procédural
<?php
error_reporting(0);
mysqli_report(MYSQLI_REPORT_OFF);
$mysqli = mysqli_connect('localhost', 'my_user', 'my_password', 'my_db');
if (mysqli_connect_errno()) {
throw new RuntimeException('mysqli connection error: ' . mysqli_connect_error());
}
/* Définir le jeu de caractère désiré après avoir établie une connexion */
mysqli_set_charset($mysqli, 'utf8mb4');
if (mysqli_errno($mysqli)) {
throw new RuntimeException('mysqli error: ' . mysqli_error($mysqli));
}
Note:
MySQLnd s'occupe toujours du jeu de caractères par défaut du serveur. Celui-ci est envoyé durant la négociation de la connexion ou l'authentification.
Libmysqlclient utilise le jeu de caractères par défaut de my.cnf ou via par un appel à mysqli_options() avant mysqli_real_connect(), mais après mysqli_init().
Note:
Style orienté objet uniquement : si la connexion a échoué, un objet est quand même retourné. Pour vérifier si la connexion a échoué, utilisez soit la fonction mysqli_connect_error() ou la propriété mysqli->connect_error comme dans l'exemple ci-dessus.
Note:
S'il est nécessaire de configurer des options, telles que le délai de connexion, mysqli_real_connect() doit être utilisé.
Note:
Appeler le constructeur sans paramètre a le même effet qu'appeler mysqli_init().
Note:
L'erreur
"Can't create TCP/IP socket (10106)"
signifie à généralement que la directive de configuration variables_order ne contient pas le caractèreE
. Sous Windows, si l'environnement n'est pas copié, la variable d'environnementSYSTEMROOT
ne sera pas disponible et PHP aura des soucis pour charger Winsock.