AGSparqlOrderBy.java

package com.franz.ag.examples;

import com.franz.ag.*;

public class AGSparqlOrderBy {

    /**
     * Demonstrates basics of using ORDER BY in SPARQL 
     *
     * @param args unused
     * @throws AllegroGraphException
     */
    public static void main(String[] args) throws AllegroGraphException {
        // Connect to server, which must already be running.
        AllegroGraphConnection ags = new AllegroGraphConnection();
        try {
            ags.enable();
        } catch (Exception e) {
            throw new AllegroGraphException("Server connection problem", e);
        }

        // Create a fresh triple store
        AllegroGraph ts = ags.renew("sparqlorderby", AGPaths.TRIPLE_STORES);

        // Load the Kennedy data
        AGUtils.loadNTriplesWithTiming(ts,AGPaths.dataSources("kennedy.ntriples"));
        
        // Index the store for querying, wait until indexing is complete.
        ts.indexAllTriples(true);

        // Query for people ordered by birth year (oldest first)
        String query =
        "PREFIX ex: <http://example.org/kennedy/> " +
        "SELECT ?fname ?lname ?year " +
        "WHERE { ?person ex:last-name ?lname . " +
                "?person ex:first-name ?fname . " +
                "?person ex:birth-year ?year " +
        "}" +
        "ORDER BY ?year ";
        
        AGUtils.doSparqlSelect(ts, query);
        
        // Query for people ordered by last name, then birth 
        // year (youngest first) 
        query =
        "PREFIX ex: <http://example.org/kennedy/> " +
        "SELECT ?fname ?lname ?year " +
        "WHERE { ?person ex:last-name ?lname . " +
                "?person ex:first-name ?fname . " +
                "?person ex:birth-year ?year " +
        "}" +
        "ORDER BY ?lname DESC(?year) ";
        
        AGUtils.doSparqlSelect(ts, query);
        
        // Close the triple store and disconnect from the server
        ts.closeTripleStore();
        ags.disable();
    }

}

Up | Next