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 :

PDO/SQL-SERVER/Android faire une requête rapportant un tableau d'objets [SQL-Server]


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2014
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2014
    Messages : 10
    Points : 10
    Points
    10
    Par défaut PDO/SQL-SERVER/Android faire une requête rapportant un tableau d'objets
    Bonjour à tous, aujourd'hui mon problème est de ramener des données d'une base SQL-SERVER en tant qu'objets pour ensuite en faire une liste sur mon application android.

    j'avais fait des tests sur une base PHP MYSQL tout à très bien fonctionné, pour information voici 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
     
    $sql="SELECT DISTINCT TOP 5 DC_Title, DC_Creator FROM [SRVERMES_Exploitation].[dbo].[OF_RESSOURCE] WHERE DC_Title LIKE '%".$QUERY."%' ";
     
    		$rs=$base->query($sql);
     
    		if (!$rs) {
    			print "PDO::errorInfo():";
    			$msg = $base->errorInfo();
    			print $msg[2] . "<br />";
    			die("Arrêt du traitement");
    		}
     
    		while ($row = $rs->fetch(PDO::FETCH_ASSOC))
    		  $output[]=$row;
     
    		print(json_encode($output));
    Seulement ce code ne fonctionne pas avec sql-server, j'ai cette erreur:
    Fatal error: Call to a member function query() on a non-object in D:\www\essai_webservice_yoann\WebServSearch.php on line 25

    j'ai donc cherché des tutos pour les requetes sur la base microsoft, j'ai essayé ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $req = $sql->requete("SELECT TOP 5 DC_Title, DC_Creator FROM [SRVERMES_Exploitation].[dbo].[OF_RESSOURCE] WHERE DC_Title LIKE '%".$QUERY."%'");
        while ($r = $req->fetch())
        {
            print_r($r);
        }
    ce qui me donne un résultat comme ceci:
    Array ( [DC_Title] => Essais de sociologie [0] => Essais de sociologie [DC_Creator] => Mauss, Marcel (1872-1950). Auteur [1] => Mauss, Marcel (1872-1950). Auteur ) Array ( [DC_Title] => René Gillouin. Essais de critique littéraire et philosophique : Mme de Noailles, Mme Colette Willy, Maurice Barrès, Charles Demange, Jean Moréas, William James [0] => René Gillouin. Essais de critique littéraire et philosophique : Mme de Noailles, Mme Colette Willy, Maurice Barrès, Charles Demange, Jean Moréas, William James [DC_Creator] => Gillouin, René. Auteur [1] => Gillouin, René. Auteur ) ...etc

    j'ai essayé ce code là:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $req = $sql->requete("SELECT TOP 5 DC_Title, DC_Creator FROM [SRVERMES_Exploitation].[dbo].[OF_RESSOURCE] WHERE DC_Title LIKE '%".$QUERY."%'");
        while ($r = $req->fetch(PDO::FETCH_OBJ))
        {
            print_r($r);
        }
    ce qui me retourne:
    stdClass Object ( [DC_Title] => Essais de sociologie [DC_Creator] => Mauss, Marcel (1872-1950). Auteur ) stdClass Object ( [DC_Title] => René Gillouin. Essais de critique littéraire et philosophique : Mme de Noailles, Mme Colette Willy, Maurice Barrès, Charles Demange, Jean Moréas, William James [DC_Creator] => Gillouin, René. Auteur )


    Dans les deux cas, j'ai un probleme avec Android ensuite, un message d'erreur de ce type:
    "Erreur de parsing :org.json.JSONException: Value stdClass of type java.lang.String cannot be converted to JSONArray"

    Voilà ma question:
    Comment faire en sorte d'avoir des objet comme retour de requete? OU SINON est ce que je peux quand meme utiliser ce resultat pour en faire une liste dans mon application android? (liste avec TITRE et CREATEUR pour chaque livre)

    J'espère que quelqu'un pourra m'aider, mon stage se fini dans une semaine, j'aimerais pouvoir afficher quelques requetes dans l'application avant de partir.

    Je vous souhaite à tous une bonne journée

  2. #2
    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
    Bon en gros, l'erreur c'est que json_encode n'arrive pas à traduire tes données. (java.lang.String dans du PHP )
    Personnellement, j'utiliserais PDO::FETCH_ASSOC comme paramétrage du fetch(), histoire d'éviter les classes ésotériques...
    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]

  3. #3
    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
    Je ne vois pas pourquoi tu veux absolument passer par un objet PHP mais bref.
    Dans ton code PHP tu produis un résultat au format JSON (enfin c'est ce qu'il y a à la fin du premier code que tu nous montres).
    D'apres le message d'erreur, tu refais l'encodage JSON à l'arrivée dans ton application Android donc forcement ça coince.

    Je te conseille de faire des essais au petit bonheur la chance.
    Par exemple, "query" devient "requete" au fur et à mesure de tes codes.

    Ton code pourrait être simplement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $sql="SELECT DISTINCT TOP 5 DC_Title, DC_Creator FROM [SRVERMES_Exploitation].[dbo].[OF_RESSOURCE] WHERE DC_Title LIKE ?"
    $sth = $base->prepare($sql);
    $sth->execute(array('%' . $QUERY . '%'));
    echo json_encode($sth->fetchAll(PDO::FETCH_ASSOC));
    Ca c'est pour PHP, à toi de bien traiter le resultat de l'autre côté.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  4. #4
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2014
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2014
    Messages : 10
    Points : 10
    Points
    10
    Par défaut
    non ce n'est pas PHP qui me renvoi l'erreur java, c'est dans mon code Android sur eclipse ça.
    En gros j'ai une base de données microsoft
    une webservice PHP qui fait appel à la base de données
    une application android qui se sert de la webservice.

    J'ai utilisé le code que tu me conseil, le resultat me convient quand je test la webservice dans un navigateur mais ça plant toujours niveau android... dois-je déplacer mon sujet dans le forum Android ou est ce qu'il est bien ici quand meme?

    En attendant ta réponse, voilà mon code sur android:
    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
     
    try{
    				JSONArray jArray = new JSONArray(result);
    				for(int i=0 ; i<jArray.length() ; i++) 
    				{					
    					//Création d'une HashMap pour insérer les informations du premier item de notre listView
    					map = new HashMap<String, String>();
    					//on insère les éléments de chaque item du fichier item.xml
    					JSONObject json_data = jArray.getJSONObject(i);
    					//on insère un élément titre et un element createur que l'on récupérera dans le textView créé dans le fichier affichageitem.xml					
    					map.put("DC_Creator",(String)json_data.getString("DC_Creator"));
    					map.put("DC_Title",(String)json_data.getString("DC_Title"));
     
    					listItem.add(map);
    					Log.i(TAG, "liste item : " + listItem.toString());
     
    				}				
    				this.catalogue.setListItem(listItem);				
    			}
    			catch(JSONException e){
    				Log.e("JSON_tag", "Erreur de parsing :" + e.toString());
    			}

    du coup avec ton parametrage du fetch, ça me retourne le meme type d'erreur dans mon code java:
    "Erreur de parsing :org.json.JSONException: Value Array of type java.lang.String cannot be converted to JSONArray"


    Je ne sais pas trop si le problème vient de mon code PHP ou de mon code JAVA... mais comme ça fonctionnait avec une base de données mySQL, je me dit que le problème vient du type d'information récupérée dans la base de données, c'est pour ça que j'ai posté ici plutot que sur le forum java ou android.


    Edit: Pardon Sabotage, je n'avais pas vu ton message, je vais essayer ce que tu me conseil, je vous fait un retour dès que possible

  5. #5
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2014
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Vosges (Lorraine)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2014
    Messages : 10
    Points : 10
    Points
    10
    Par défaut
    Alors merci Sabotage, c'est ta remarque qui m'a permis de résoudre mon problème!

    j'ai remplacé ce code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $req = $sql->requete("SELECT TOP 5 DC_Title, DC_Creator FROM [SRVERMES_Exploitation].[dbo].[OF_RESSOURCE] WHERE DC_Title LIKE '%".$QUERY."%'");
        while ($r = $req->fetch(PDO::FETCH_ASSOC))
        {
            print_r($r);
        }
    par celui-ci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $req = $sql->requete("SELECT TOP 5 DC_Title, DC_Creator FROM [SRVERMES_Exploitation].[dbo].[OF_RESSOURCE] WHERE DC_Title LIKE '%".$QUERY."%'");
        while ($r = $req->fetch(PDO::FETCH_ASSOC))
        {
            $output[]=$r;;
        }
    	print(json_encode($output));
    il FALLAIT mettre json_encode, chose que j'avais fait avec le code mySQL et que je n'avais pas fait avec mon code sql-server.

    Je vous remercie de vous etre occupé de mon cas, je n'aurais pas trouvé sans être venu ici, le fait d'en parler ça débloque des choses.

    Merci encore et surement à bientot :$

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

Discussions similaires

  1. [SQL server CE] Effectuée une requête
    Par afrodje dans le forum VB.NET
    Réponses: 0
    Dernier message: 03/04/2009, 11h32
  2. Réponses: 3
    Dernier message: 16/05/2007, 13h48
  3. [SQL Server]Problème avec une requête récursive
    Par evans dans le forum Langage SQL
    Réponses: 3
    Dernier message: 05/04/2006, 20h16
  4. [SQL-SERVER 2000] Problème de requête sur une seule ligne
    Par Sytchev3 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 05/04/2006, 16h54
  5. [SQL Server 8] Regrouper 2 requêtes en une ?
    Par Baquardie dans le forum Langage SQL
    Réponses: 3
    Dernier message: 22/06/2004, 22h22

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