(PHP 5, PHP 7, PHP 8)
mysqli::__construct -- mysqli::connect -- mysqli_connect — Ouvre une connexion à un serveur MySQL
Style orienté objet
$hostname
= null
,$username
= null
,$password
= null
,$database
= null
,$port
= null
,$socket
= null
$hostname
= null
,$username
= null
,$password
= null
,$database
= null
,$port
= null
,$socket
= null
Style procédural
$hostname
= null
,$username
= null
,$password
= null
,$database
= null
,$port
= null
,$socket
= null
Ouvre une connexion au serveur MySQL.
hostname
Peut être un nom d'hôte ou une adresse IP. Lorsqu'on passe null
, la valeur est récupérée depuis mysqli.default_host. 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 ou null
pour supposer le nom d'utilisateur en fonction de l'option ini mysqli.default_user.
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
La base de données par défaut à utiliser lors de l'exécution de requêtes ou null
.
port
Le numéro de port auquel tenter de se connecter au serveur MySQL ou null
pour supposer le port en fonction de l'option ini mysqli.default_port.
socket
Le socket ou le pipe nommé qui doit être utilisé, ou null
pour supposer le socket en fonction de l'option ini mysqli.default_socket.
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_connect() retourne un objet qui représente la connexion au serveur MySQL, ou false
si une erreur survient.
mysqli::connect() renvoie true
en cas de succès ou false
si une erreur survient. Antérieur à PHP 8.1.0, renvoie null
en cas de succès.
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.
Version | Description |
---|---|
8.1.0 | mysqli::connect() retourne désormais true au lieu de null en cas de succès. |
7.4.0 | Tous les paramètres sont désormais nullable. |
Exemple #1 Exemple mysqli::__construct()
Style orienté objet
<?php
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$mysqli = new mysqli('localhost', 'my_user', 'my_password', 'my_db');
$mysqli->set_charset('utf8mb4');
printf("Success... %s\n", $mysqli->host_info);
Style procédural
<?php
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$mysqli = mysqli_connect('localhost', 'my_user', 'my_password', 'my_db');
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);
}
$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());
}
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.