(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.
      
usernameLe 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).
      
databaseSi fourni, spécifiera la base de données par défaut à utiliser lors de l'exécution de requêtes.
portSpécifie le numéro du port pour la connexion au serveur MySQL.
socketSpécifie le socket ou le nom du tunnel à utiliser.
Note:
Spécifier le paramètre
socketne 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'environnementSYSTEMROOTne sera pas disponible et PHP aura des soucis pour charger Winsock.