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 :

odbc fetch array [ODBC]


Sujet :

PHP & Base de données

  1. #1
    Nouveau membre du Club Avatar de ideox
    Homme Profil pro
    Collégien
    Inscrit en
    Décembre 2014
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Décembre 2014
    Messages : 47
    Points : 32
    Points
    32
    Par défaut odbc fetch array
    Bonsoir, voici mon problème.
    J'ai fait un script de login, qui a pour but de chercher dans ma bdd un code (donc dans une colonne appeler Code);
    Si le code est bon , alors ils sont rediriger vers une autre page .
    Si il est pas bon, erreur.
    Si la case est vide -> erreur.

    Voilà le code,
    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
    <?php
    //Connexion SQL
    require_once('db_config.php');
     
    //Définis les variables
    $code = isset($_POST['Code']) ? mysql_real_escape_string(trim($_POST['Code'])) : '';
    $errors = array();
    $success = false;
    if(isset($_POST) && !empty($_POST)){
    	require_once('db.php');
     
    	//Les champs ne doivent pas êtres vides.
    	if (empty($code)) {
    		die('Entrez un code membre.');
    	}
    	// Formulaire d'interrogation sql.
    	if(count($errors) == 0){
    		$sql = "SELECT UID FROM  PS_DATABASE.dbo.Compte WHERE Code = '".$code."'";
    				$stmt = odbc_prepare($GLOBALS['dbConn'],$sql);
    				$res = odbc_execute($stmt);
    			while( $row = odbc_fetch_array($res) ) {
    				print_r($row);
    			}
    			if(empty($row))
    		echo "aucun retour";
    	}
    }
    // Fin
    if($success === false){
    	require_once('log_view.php');
    }else{
    	require_once('success.view.php');
    }
    ?>
    Mais j'ai une erreur de ' mysql_real_escape_string ' ligne 6, sachant que sur d'autre de mes script cela marche bien.
    Et le odbc_fetch_array qui a se qu eje vois manque une ressource boelan..
    J'utilise Wamp Server, version du php : 5.5.12 et Apache : 2.4.9

    Merci.

  2. #2
    Membre éclairé
    Homme Profil pro
    Formateur en informatique
    Inscrit en
    Septembre 2012
    Messages
    416
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Formateur en informatique
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Septembre 2012
    Messages : 416
    Points : 747
    Points
    747
    Par défaut
    Bonjour

    j'ai une erreur de ' mysql_real_escape_string ' ligne 6
    Une erreur "Deprecated" ?

    Si oui, avec php 5.5, c'est normal. Les fonctions mysql_ sont dépréciées et ne devraient plus être utilisées.

    Tu peux utiliser "mysqli_real_escape_string" à la place.

    Plus d'infos sur la doc PHP : http://php.net/manual/fr/function.my...ape-string.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
    ya que moi qui trouve ça bizarre d'utiliser mysql_real_escape_string pour alimenter une requête exécutée par odbc ?
    odbc gère les requêtes préparées (comme mylsqi) donc utilise la requête préparée au lieu de bidouiller avec les fonction mysql :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $code = isset($_POST['Code']) ? trim($_POST['Code']) : '';
     
    //...
     
    // marque-place pour le paramètre
    $sql = "SELECT UID FROM  PS_DATABASE.dbo.Compte WHERE Code = ?";
    $stmt = odbc_prepare($GLOBALS['dbConn'],$sql);
    // on passe $code en paramètre de la requête
    $res = odbc_execute($stmt, array($code));
    while( $row = odbc_fetch_array($res) ) {
    	print_r($row);
    }
    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]

  4. #4
    Nouveau membre du Club Avatar de ideox
    Homme Profil pro
    Collégien
    Inscrit en
    Décembre 2014
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Décembre 2014
    Messages : 47
    Points : 32
    Points
    32
    Par défaut
    Bonjour, tout d'abord merci Celira.
    Mais un problème persiste avec odbc_fetch_array (j'ai eu ce problème x fois).
    Image
    Quelle est la fameuse ressource ?
    Mon code ressemble donc à cela maintenant :
    Code php : 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
    <?php
    //Connexion SQL
    require_once('db_config.php');
     
    //On définis les variables
    $code = isset($_POST['Code']) ? trim($_POST['Code']) : '';
    $errors = array();
    $success = false;
    if(isset($_POST) && !empty($_POST)){
    require_once('db.php');
     
    	//Les champs ne doivent pas êtres vides.
    	if (empty($code)) {
    		echo"Entrez un code membre.";
    	}
     
    	//Requête SQL + ODBC Prepare
    	if(count($errors) == 0){
    	$sql = "SELECT * FROM  PS_DATABASE.dbo.Compte WHERE Code = '".$code."'";
    	$stmt = odbc_prepare($GLOBALS['dbConn'],$sql);
     
    	//On passe $code en paramètre de la requête
    	$res = odbc_execute($stmt, array($code));
     
    	while( $row = odbc_fetch_array($res) ) {
    	print_r($row);
    }
    }
    }
    // Fin
    if($success === false){
    	require_once('log_view.php');
    }else{
    	require_once('success.view.php');
    }
    ?>

    Merci,

  5. #5
    Nouveau membre du Club Avatar de ideox
    Homme Profil pro
    Collégien
    Inscrit en
    Décembre 2014
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 23
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Décembre 2014
    Messages : 47
    Points : 32
    Points
    32
    Par défaut [RESOLU]
    BUMP, soucis résolut!
    Il manquais une vérification comme cela
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if(!odbc_execute($stmt))
    				{
    					$errors[] = "Connexion au serveur saturé!";
    				}
    Après la $sql = "query_ici";
    et avant le
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    $reponse = odbc_fetch_array($stmt)

    Merci!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [MySQL] Limite d'un fetch array
    Par katf413 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 26/08/2008, 08h59
  2. fetch array vs count ou autre
    Par wormzoom dans le forum Langage
    Réponses: 10
    Dernier message: 17/07/2008, 22h51
  3. [MySQL] tester si un fetch array est vide
    Par boubourse92 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 04/04/2008, 12h30
  4. [MySQL] mysqli fetch array
    Par Kiwimenthe dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 16/08/2007, 09h17
  5. probleme avec mysql fetch array
    Par philsand77 dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 19/04/2007, 07h56

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