AGFederationFreetextSearch.java

package com.franz.ag.examples;

import com.franz.ag.*;

public class AGFederationFreetextSearch {

    /**
     * Demonstrates freetext search in a federation of triple stores.
     * 
     * @param args unused
     * @throws AllegroGraphException
     */
    public static void main(String[] args) throws AllegroGraphException {
        
        // Connect to the default server, which must already be running.
        AllegroGraphConnection ags = new AllegroGraphConnection();
        try {
            ags.enable();
        } catch (Exception e) {
            throw new AllegroGraphException("Server connection problem.", e);
        }

        // Create triple stores for this example
        AllegroGraph ts1 = ags.renew("store1", AGPaths.TRIPLE_STORES);
        AllegroGraph ts2 = ags.renew("store2", AGPaths.TRIPLE_STORES);
        
        // Create a federated store consisting of the first 2 open stores above 
        AllegroGraph[] parts = {ts1,ts2};
        AllegroGraph fed = ags.federate("federationfreetext", parts, true);
        
        // Register any predicates whose objects are to be searched
        ts1.registerFreetextPredicate("<http://www.w3.org/2000/01/rdf-schema#comment>");
        ts2.registerFreetextPredicate("<http://www.w3.org/2000/01/rdf-schema#comment>");
        
        // Add some triples to the store
        ts1.addStatement("\"Jans\"", "!rdfs:comment", "\"Born in Emmen in the Netherlands\"");
        ts2.addStatement("\"Gary\"", "!rdfs:comment", "\"Born in Springfield in the USA\"");
        ts2.addStatement("\"Henk\"", "!rdfs:label", "\"Born in Emmermeer in the Netherlands\"");
        
        // Search the federation for subjects whose object contains emmen and born
        ValueObject[] v = fed.getFreetextUniqueSubjects("(and 'emmen' 'born')");
        AGUtils.printObjectArray("Subjects matching search: (and 'emmen' 'born')", v);
        
        // Search the federation for statements whose object contains emmen and born
        Cursor cc = fed.getFreetextStatements("(and 'emmen' 'born')");
        AGUtils.showTriples(cc);
                
        // Close all stores and disconnect from the server
        fed.closeTripleStore();
        ts1.closeTripleStore();
        ts2.closeTripleStore();
        ags.disable();
    }
    
}

Up | Next