IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Passage de Mysql à Mysqli


Sujet :

PHP & Base de données

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Ingénieur sécurité
    Inscrit en
    Octobre 2016
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Sénégal

    Informations professionnelles :
    Activité : Ingénieur sécurité
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2016
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Passage de Mysql à Mysqli
    Bonjour. En testant un applicatif de gestion scolaire , le navigateur m'indique une erreur :
    Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in C:\wamp\www\Gest_Ecole\index_principal.php on line 21
    Voici le fichier index_principal.php

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    session_start();
     
      include "config.php";
     
    	mysql_connect($gestclasse_config['param_connexion']['serveur'],$gestclasse_config['param_connexion']['user'],$gestclasse_config['param_connexion']['passe']);
    	@mysql_select_db($gestclasse_config['param_connexion']['base']);
     
      if (!isset($_SESSION['language_application']))
      {
    		 $req=mysql_query("SELECT * FROM `config` WHERE parametre='langue_defaut'");
     
    		      if (mysql_num_rows($req)=="")
    		{
    				$_SESSION['language_application']="fr-FR";
    		}
    		else
    		{
    				$_SESSION['language_application']=mysql_result($req,0,'valeur');
    		}
      }
    	$req=mysql_query("SELECT * FROM `config` WHERE parametre='langue_defaut'");
    	if (mysql_num_rows($req)=="")
     
     
    Pour passer de Mysql à Mysqli voila ce que j'ai fait:
     
     
    session_start();
     
      include "config.php";
     
    	//sql_connect($gestclasse_config['param_connexion']['serveur'],$gestclasse_config['param_connexion']['user'],$gestclasse_config['param_connexion']['passe']);
    		//n se connecte a la base de donnees
    		 $conn=mysqli_connect($gestclasse_config['param_connexion']['serveur'],$gestclasse_config['param_connexion']['user'],$gestclasse_config['param_connexion']['passe']);
    	//ysql_select_db($gestclasse_config['param_connexion']['base']);
    	/* Vérification de la connexion */
    if (mysqli_connect_errno()) {
        printf("Échec de la connexion : %s\n", mysqli_connect_error());
        exit();
     
      if (!isset($_SESSION['language_application']))
      {
    		   // on crée la requete
    		   $req="SELECT * FROM `config` WHERE parametre='langue_defaut'";
    			// on envoie la requête
               $res = $conn->query($req);
    		     //f (mysql_num_rows($req)=="")
                    if ( $row_cnt = mysqli_num_rows($res)=="");
    		{
    				$_SESSION['language_application']="fr-FR";
    		}
    		else
    		{
    				$_SESSION['language_application']=mysqli_num_rows(mysqli_result $req,0,'valeur')
    		}
      }
    	$req="SELECT * FROM `config` WHERE parametre='langue_defaut'";
    	if  mysqli_num_rows($res=="")
    	{
    		$langue_defaut="fr-FR";
    	}
    	else
    	{
    		$langue_defaut=mysqli_num_rows(mysqli_result $req,0,'valeur');
    	}

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    C'est exactement ce qui est indiqué dans l'erreur : l'extension mysql est obsolète, il faut utiliser PDO ou mysqli.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    En d'autres termes, il faut remplacer toutes les fonctions mysql_xxxxx par leur équivalent mysqli ou PDO.
    A noter que l'API mysql est obsolète depuis PHP 5.5 et supprimée en PHP7, ce qui veut dire que lorsque tu exécuteras ce code sur un serveur PHP 7, il va purement et simplement ne pas fonctionner.
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

Discussions similaires

  1. [MySQL] Passage de mysql à mysqli
    Par awkwardm dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 12/10/2016, 17h03
  2. [MySQLi] Passage d'un code de l'ext. mysql à mysqli
    Par santiago_cw dans le forum Requêtes
    Réponses: 1
    Dernier message: 04/01/2007, 03h19
  3. Besoin d'aide pour passage de mysql a sql server
    Par mobscene dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 07/12/2005, 07h55
  4. [SGBD] MySQL/MySQLi
    Par Tizard dans le forum SQL Procédural
    Réponses: 6
    Dernier message: 05/12/2005, 10h51
  5. passage de Mysql 3.23 a 4.1 avec php4
    Par epeichette dans le forum Installation
    Réponses: 4
    Dernier message: 09/04/2005, 21h33

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo