Size: 2492
Comment:
|
Size: 4861
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 5: | Line 5: |
== iTQL == |
|
Line 7: | Line 9: |
This has a graphical user interface, which it very helpful to users, but not programmatically useful. The interface is described here: | This has a graphical user interface, which it very helpful to users, but not programmatically useful. The interface is described here: http://www.fedora-commons.org/confluence/display/FCR30/Resource+Index+Search |
Line 9: | Line 11: |
http://www.fedora-commons.org/confluence/display/FCR30/Resource+Index+Search | We have prepared a number of useful iTQL queries, that can serve as examples Find all direct subclasses of doms:ContentModel_File in the Base collection {{{ select $object from <#ri> where $object <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> <info:fedora/doms:ContentModel_File> and $object <http://doms.statsbiblioteket.dk/relations/default/0/1/#isPartOfCollection> <info:fedora/doms:DOMS_Base_Collection> }}} Find the ancestors of doms:ContentModel_AudioPreservationFile {{{ select $object from <#ri> where walk( <info:fedora/doms:ContentModel_AudioPreservationFile> <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object ) }}} Find all the any-level children of doms:ContentModel_DOMS {{{ select $subject from <#ri> where walk( $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> <info:fedora/doms:ContentModel_DOMS> and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object ); }}} Same again, with different output {{{ select $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object from <#ri> where walk( $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> <info:fedora/doms:ContentModel_DOMS> and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object ); }}} Anylevel children of ContentModel DOMS in the base collection {{{ select $subject from <#ri> where walk( $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> <info:fedora/doms:ContentModel_DOMS> and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object ) and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#isPartOfCollection> <info:fedora/doms:DOMS_Base_Collection> }}} Any objects in the Root collection or subcollections {{{ select $subject '<isPartOfCollection>' $object from <#ri> where walk( $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#isPartOfCollection> <info:fedora/doms:Root_Collection> and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#isPartOfCollection> $object ) }}} |
Line 31: | Line 92: |
}}} which is nicely outdated. | }}} which is unfortunately outdated. |
Fedora Resource Index
The Fedora Resource Index service is described in http://www.fedora-commons.org/confluence/display/FCR30/Resource+Index
iTQL
The resource index is queried by iTQL. A guide to iTQL can be found on http://docs.mulgara.org/itqlcommands/select.html
This has a graphical user interface, which it very helpful to users, but not programmatically useful. The interface is described here: http://www.fedora-commons.org/confluence/display/FCR30/Resource+Index+Search
We have prepared a number of useful iTQL queries, that can serve as examples
Find all direct subclasses of doms:ContentModel_File in the Base collection
select $object from <#ri> where $object <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> <info:fedora/doms:ContentModel_File> and $object <http://doms.statsbiblioteket.dk/relations/default/0/1/#isPartOfCollection> <info:fedora/doms:DOMS_Base_Collection>
Find the ancestors of doms:ContentModel_AudioPreservationFile
select $object from <#ri> where walk( <info:fedora/doms:ContentModel_AudioPreservationFile> <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object )
Find all the any-level children of doms:ContentModel_DOMS
select $subject from <#ri> where walk( $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> <info:fedora/doms:ContentModel_DOMS> and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object );
Same again, with different output
select $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object from <#ri> where walk( $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> <info:fedora/doms:ContentModel_DOMS> and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object );
Anylevel children of ContentModel DOMS in the base collection
select $subject from <#ri> where walk( $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> <info:fedora/doms:ContentModel_DOMS> and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#extendsModel> $object ) and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#isPartOfCollection> <info:fedora/doms:DOMS_Base_Collection>
Any objects in the Root collection or subcollections
select $subject '<isPartOfCollection>' $object from <#ri> where walk( $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#isPartOfCollection> <info:fedora/doms:Root_Collection> and $subject <http://doms.statsbiblioteket.dk/relations/default/0/1/#isPartOfCollection> $object )
For programs, there are two interfaces.
- The first is the REST-based interface defined in
The second is the Fedora client, which has a method getTuples(). See
http://www.fedora-commons.org/documentation/3.0/javadocs/index.html?fedora/client/FedoraClient.html.
The method getTuples() has the following javadoc
/** * Get tuples from the remote resource index. The map contains * <em>String</em> values for parameters that should be passed to the * service. Two parameters are required: 1) lang 2) query Two parameters to * the risearch service are implied: 1) type = tuples 2) format = sparql See * http://www.fedora.info/download/2.0/userdocs/server/webservices/risearch/#app.tuples */
which is unfortunately outdated.The method returns an org.trippi.TupleIterator which parses the sparql result. The javadoc for this can be found on http://trippi.sourceforge.net/api/org/trippi/TupleIterator.html
Note that the page is not updated either, the releases can be found in the svn, and has reached version 1.4. Fedora uses 1.3.2, which is unknown, but 1.3.1 can be checked out. Look at http://sourceforge.net/svn/?group_id=123675 to do this. The result consist of a list of maps. The iterator iterates through this list, returning maps. The iterator has a method, names, giving the keys to each map. The values in the maps are of type Node, see
http://jrdf.sourceforge.net/0.3.4/doc/javadoc/org/jrdf/graph/Node.html In practice each node will always be a Literal node or a URI reference Node or a Blank node, see the following
http://jrdf.sourceforge.net/0.3.4/doc/javadoc/org/jrdf/graph/Literal.html,
http://jrdf.sourceforge.net/0.3.4/doc/javadoc/org/jrdf/graph/URIReference.html,
http://jrdf.sourceforge.net/0.3.4/doc/javadoc/org/jrdf/graph/BlankNode.html