mysqli::__construct

mysqli::connect

mysqli_connect

(PHP 5, PHP 7, PHP 8)

mysqli::__construct -- mysqli::connect -- mysqli_connectOuvre une connexion à un serveur MySQL

Description

Style orienté objet

publicmysqli::__construct(
    ?string$hostname = null,
    ?string$username = null,
    ?string$password = null,
    ?string$database = null,
    ?int$port = null,
    ?string$socket = null
)
publicmysqli::connect(
    ?string$hostname = null,
    ?string$username = null,
    ?string$password = null,
    ?string$database = null,
    ?int$port = null,
    ?string$socket = null
): bool

Style procédural

mysqli_connect(
    ?string$hostname = null,
    ?string$username = null,
    ?string$password = null,
    ?string$database = null,
    ?int$port = null,
    ?string$socket = null
): mysqli|false

Ouvre une connexion au serveur MySQL.

Liste de paramètres

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ètre hostname.

Valeurs de retour

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.

Erreurs / Exceptions

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.

Historique

VersionDescription
8.1.0mysqli::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.

Exemples

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));
}

Notes

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ère E. Sous Windows, si l'environnement n'est pas copié, la variable d'environnement SYSTEMROOT ne sera pas disponible et PHP aura des soucis pour charger Winsock.

Voir aussi

To Top