Struct QueryDataset
pub struct QueryDataset {
default: Option<Vec<GraphName>>,
named: Option<Vec<NamedOrBlankNode>>,
}
Expand description
A SPARQL query dataset specification
Fieldsยง
ยงdefault: Option<Vec<GraphName>>
ยงnamed: Option<Vec<NamedOrBlankNode>>
Implementationsยง
ยงimpl QueryDataset
impl QueryDataset
pub fn is_default_dataset(&self) -> bool
pub fn is_default_dataset(&self) -> bool
Checks if this dataset specification is the default one (i.e. the default graph is the store default graph and all the store named graphs are available)
use oxigraph::sparql::Query;
assert!(Query::parse("SELECT ?s ?p ?o WHERE { ?s ?p ?o . }", None)?
.dataset()
.is_default_dataset());
assert!(!Query::parse(
"SELECT ?s ?p ?o FROM <http://example.com> WHERE { ?s ?p ?o . }",
None
)?
.dataset()
.is_default_dataset());
pub fn default_graph_graphs(&self) -> Option<&[GraphName]>
pub fn default_graph_graphs(&self) -> Option<&[GraphName]>
Returns the list of the store graphs that are available to the query as the default graph or None
if the union of all graphs is used as the default graph
This list is by default only the store default graph
pub fn set_default_graph_as_union(&mut self)
pub fn set_default_graph_as_union(&mut self)
Sets if the default graph for the query should be the union of all the graphs in the queried store
pub fn set_default_graph(&mut self, graphs: Vec<GraphName>)
pub fn set_default_graph(&mut self, graphs: Vec<GraphName>)
Sets the list of graphs the query should consider as being part of the default graph.
By default only the store default graph is considered.
use oxigraph::model::NamedNode;
use oxigraph::sparql::Query;
let mut query = Query::parse("SELECT ?s ?p ?o WHERE { ?s ?p ?o . }", None)?;
let default = vec![NamedNode::new("http://example.com")?.into()];
query.dataset_mut().set_default_graph(default.clone());
assert_eq!(
query.dataset().default_graph_graphs(),
Some(default.as_slice())
);
pub fn available_named_graphs(&self) -> Option<&[NamedOrBlankNode]>
pub fn available_named_graphs(&self) -> Option<&[NamedOrBlankNode]>
Returns the list of the available named graphs for the query or None
if all graphs are available
pub fn set_available_named_graphs(
&mut self,
named_graphs: Vec<NamedOrBlankNode>,
)
pub fn set_available_named_graphs( &mut self, named_graphs: Vec<NamedOrBlankNode>, )
Sets the list of allowed named graphs in the query.
use oxigraph::model::NamedNode;
use oxigraph::sparql::Query;
let mut query = Query::parse("SELECT ?s ?p ?o WHERE { ?s ?p ?o . }", None)?;
let named = vec![NamedNode::new("http://example.com")?.into()];
query
.dataset_mut()
.set_available_named_graphs(named.clone());
assert_eq!(
query.dataset().available_named_graphs(),
Some(named.as_slice())
);
Trait Implementationsยง
ยงimpl Clone for QueryDataset
impl Clone for QueryDataset
ยงfn clone(&self) -> QueryDataset
fn clone(&self) -> QueryDataset
1.0.0 ยท Sourceยงfn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreยงimpl Debug for QueryDataset
impl Debug for QueryDataset
ยงimpl Hash for QueryDataset
impl Hash for QueryDataset
ยงimpl PartialEq for QueryDataset
impl PartialEq for QueryDataset
impl Eq for QueryDataset
impl StructuralPartialEq for QueryDataset
Auto Trait Implementationsยง
impl Freeze for QueryDataset
impl RefUnwindSafe for QueryDataset
impl Send for QueryDataset
impl Sync for QueryDataset
impl Unpin for QueryDataset
impl UnwindSafe for QueryDataset
Blanket Implementationsยง
ยงimpl<T> ArchivePointee for T
impl<T> ArchivePointee for T
ยงtype ArchivedMetadata = ()
type ArchivedMetadata = ()
ยงfn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Sourceยงimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Sourceยงfn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
ยงimpl<T> CallHasher for T
impl<T> CallHasher for T
Sourceยงimpl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
ยงimpl<F, W, T, D> Deserialize<With<T, W>, D> for F
impl<F, W, T, D> Deserialize<With<T, W>, D> for F
ยงfn deserialize(
&self,
deserializer: &mut D,
) -> Result<With<T, W>, <D as Fallible>::Error>
fn deserialize( &self, deserializer: &mut D, ) -> Result<With<T, W>, <D as Fallible>::Error>
ยงimpl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
ยงfn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
, which can then be
downcast
into Box<dyn ConcreteType>
where ConcreteType
implements Trait
.ยงfn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
, which can then be further
downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.ยงfn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
โs vtable from &Trait
โs.ยงfn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
โs vtable from &mut Trait
โs.ยงimpl<T> DowncastSend for T
impl<T> DowncastSend for T
ยงimpl<T> DowncastSync for T
impl<T> DowncastSync for T
ยงimpl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
ยงfn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
ยงimpl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
ยงfn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.ยงimpl<T> Instrument for T
impl<T> Instrument for T
ยงfn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
ยงfn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Sourceยงimpl<T> IntoEither for T
impl<T> IntoEither for T
Sourceยงfn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSourceยงfn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more