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

SPARQL Discussion :

Valeur de retour d'une requête


Sujet :

SPARQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    131
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2010
    Messages : 131
    Points : 44
    Points
    44
    Par défaut Valeur de retour d'une requête
    Bonsoir, j'ai cette requête sparql:
    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
     
     try{
    			String queryString =	"SELECT  ?label ?comment " + " WHERE { " +
                                         "<"+uri2+">  <http://www.w3.org/2000/01/rdf-schema#label> ?label." +
    					"<"+uri2+">  <http://www.w3.org/2000/01/rdf-schema#comment> ?comment." +
    					"  FILTER langMatches(lang(?label), 'en') " +
    					"  FILTER langMatches(lang(?comment), 'en')}";
    			Query query = QueryFactory.create(queryString);
    			// initializing queryExecution factory with remote service.
    			// **this actually was the main problem I couldn't figure out.**
    			QueryExecution qexec = QueryExecutionFactory.sparqlService("http://dbpedia.org/sparql", query);
     
    			try {
    				ResultSet results = qexec.execSelect();
    			    for (; results.hasNext();) {
    			    	QuerySolution sol = results.next();
                                    if (sol.get("?label")!= null ){
                                    vnom2.addElement(sol.get("?label"));}
                                    else vnom2.addElement(null );
     
                                    if (sol.get("?label")!= null ){
     
                                    vlabel2.addElement(sol.get("?label"));}
                                    else vlabel2.addElement(null);
     
                                    if (sol.get("?comment")!= null){
     
                                  vcomment2.addElement(sol.get("?comment"));
     
                                }
                                    else vcomment2.addElement(null);
     
     
                                }
    			}catch(Exception e1){
    				e1.printStackTrace();
    			}
    			finally {
    			   qexec.close();
    			}
     
        	}catch(Exception e1){
        		e1.printStackTrace();
        	}
                             }
                        }
    est ce que les tests que j'ai fait au niveau des variables ?label et ?nom sont corrects ???? cad si une requête ne trouve pas la valeur ?label dans dbpédia, elle retourne la valeur "null"????? et merci d'avance

  2. #2
    Rédacteur/Modérateur
    Avatar de Metafire18
    Homme Profil pro
    Ingénieur de recherche Orange Labs
    Inscrit en
    Décembre 2007
    Messages
    777
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Territoire de Belfort (Franche Comté)

    Informations professionnelles :
    Activité : Ingénieur de recherche Orange Labs

    Informations forums :
    Inscription : Décembre 2007
    Messages : 777
    Points : 1 894
    Points
    1 894
    Billets dans le blog
    1
    Par défaut
    Lorsque tu utilises la méthode get de tes objets QuerySolution, il me semble qu'il faut ôter les points d'interrogation. Par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.out.println(sol.get("label") + "\n" + sol.get("comment"));
    A essayer...
    Pas de grandeur pour qui veut grandir. Pas de modèle pour qui cherche ce qu'il n'a jamais vu.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    131
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2010
    Messages : 131
    Points : 44
    Points
    44
    Par défaut
    non en fait j'ai pas de problème par rapport les valeurs ?label et ?nom que la requête trouve et qui existe dans dbpédia, mais j'ai plutôt un problème par rapport les variables qu'elle ne trouve pas ! je veux insérer "null" dans mon vecteur à chaque fois que ma requête ne trouve pas de valeur dans dbpédia, j'espère que je trouve chez vous une réponse )) et merciiii bcp

  4. #4
    Membre à l'essai
    Inscrit en
    Mai 2006
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 4
    Points : 10
    Points
    10
    Par défaut
    SPARQL ne retourne une valeur null (UNBOUND dans la spécification de SPARQL) que lorsque tu utilises l'opérateur OPTIONAL.

    Donc ta requête ne renverra que les noms et commentaires anglais de uri2. Si elle n'en a pas, tu n'auras pas de résultat.

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

Discussions similaires

  1. Valeur de retour d'une requête "select"
    Par pussyycat dans le forum SPARQL
    Réponses: 0
    Dernier message: 06/01/2013, 23h03
  2. [MySQL] Valeur de retour d'une requête UPDATE
    Par Eagle959 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 01/01/2007, 15h58
  3. Valeur de retour d'une procédure stockée
    Par Rudyweb dans le forum MFC
    Réponses: 4
    Dernier message: 25/02/2005, 17h52
  4. [VB6] Valeur de retour pour une Form
    Par preverse dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 17/08/2004, 17h16
  5. Valeur de retour d'une procédure externe
    Par elekis dans le forum x86 32-bits / 64-bits
    Réponses: 4
    Dernier message: 16/04/2004, 16h45

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