📄 graphrdb.java
字号:
throw new JenaException("Error - GraphRDB.delete(Triple) failed to find a suitable store for the triple:"+t.toString());
}
/** Delete a list of triples.
*
* @param triples List to be deleted. This is unchanged by the call.
*/
public void delete( List triples ) {
checkOpen();
ArrayList localTriples = new ArrayList( triples );
SpecializedGraph.CompletionFlag complete = new SpecializedGraph.CompletionFlag();
Iterator it = m_specializedGraphs.iterator();
while( it.hasNext() ) {
SpecializedGraph sg = (SpecializedGraph) it.next();
if( sg instanceof SpecializedGraphReifier && m_reificationBehaviour == OPTIMIZE_AND_HIDE_ONLY_FULL_REIFICATIONS)
continue; // don't let the reifier graphs see partial reifications
sg.delete( localTriples, complete);
if( complete.isDone())
return;
}
throw new JenaException("Error - GraphRDB.delete(Triple) failed to find a suitable store for at least one triple:"+triples.get(0).toString());
}
/* (non-Javadoc)
* @see com.hp.hpl.jena.graph.Graph#size()
*/
public int graphBaseSize() {
checkOpen();
int result = 0;
Iterator it = m_specializedGraphs.iterator();
while( it.hasNext() ) {
SpecializedGraph sg = (SpecializedGraph) it.next();
if( sg instanceof SpecializedGraphReifier &&
(m_reificationBehaviour == OPTIMIZE_AND_HIDE_ONLY_FULL_REIFICATIONS ||
m_reificationBehaviour == OPTIMIZE_AND_HIDE_FULL_AND_PARTIAL_REIFICATIONS))
continue; // don't let the reifier graphs see partial reifications
result += sg.tripleCount();
}
return result;
}
/* (non-Javadoc)
* @see com.hp.hpl.jena.graph.Graph#contains(com.hp.hpl.jena.graph.Triple)
*/
public boolean graphBaseContains(Triple t) {
checkOpen();
SpecializedGraph.CompletionFlag complete = new SpecializedGraph.CompletionFlag();
Iterator it = m_specializedGraphs.iterator();
while( it.hasNext() ) {
SpecializedGraph sg = (SpecializedGraph) it.next();
if( sg instanceof SpecializedGraphReifier &&
(m_reificationBehaviour == OPTIMIZE_AND_HIDE_ONLY_FULL_REIFICATIONS ||
m_reificationBehaviour == OPTIMIZE_AND_HIDE_FULL_AND_PARTIAL_REIFICATIONS))
continue; // don't let the reifier graphs see partial reifications
boolean result = sg.contains( t, complete);
if( result == true || complete.isDone() == true )
return result;
}
return false;
}
/* (non-Javadoc)
* @see com.hp.hpl.jena.graph.Graph#find(com.hp.hpl.jena.graph.TripleMatch)
*/
public ExtendedIterator graphBaseFind(TripleMatch m) {
checkOpen();
ExtendedIterator result = NullIterator.instance;
SpecializedGraph.CompletionFlag complete = new SpecializedGraph.CompletionFlag();
Iterator it = m_specializedGraphs.iterator();
while( it.hasNext() ) {
SpecializedGraph sg = (SpecializedGraph) it.next();
if( sg instanceof SpecializedGraphReifier &&
(m_reificationBehaviour == OPTIMIZE_AND_HIDE_ONLY_FULL_REIFICATIONS ||
m_reificationBehaviour == OPTIMIZE_AND_HIDE_FULL_AND_PARTIAL_REIFICATIONS))
continue; // don't let the reifier graphs see partial reifications
ExtendedIterator partialResult = sg.find( m, complete);
result = result.andThen(partialResult);
if( complete.isDone())
break;
}
return SimpleEventManager.notifyingRemove( this, result );
}
public ExtendedIterator reifierTriples( TripleMatch m )
{ return NullIterator.instance; }
public int reifierSize()
{ return 0; }
/* (non-Javadoc)
* @see com.hp.hpl.jena.graph.Graph#getBulkUpdateHandler()
*/
public BulkUpdateHandler getBulkUpdateHandler()
{ return new DBBulkUpdateHandler( this ); }
/*
* (non-Javadoc)
* @see com.hp.hpl.jena.graph.Graph#getReifier()
*/
public Reifier getReifier() {
if (m_reifier == null)
m_reifier = new DBReifier( this, style, m_specializedGraphReifiers, m_specializedGraphReifiers );
return m_reifier;
}
/* (non-Javadoc)
* @see com.hp.hpl.jena.graph.Graph#getPrefixMapping()
*/
public PrefixMapping getPrefixMapping() {
if( m_prefixMapping == null)
m_prefixMapping = new DBPrefixMappingImpl( m_properties );
return m_prefixMapping;
}
/* (non-Javadoc)
* @see com.hp.hpl.jena.graph.Graph#getTransactionHandler()
*/
public TransactionHandler getTransactionHandler() {
return new DBTransactionHandler(m_driver, this);
}
/* (non-Javadoc)
* @see com.hp.hpl.jena.graph.Graph#close()
*/
public synchronized void close() {
if( m_specializedGraphs != null) {
Iterator it = m_specializedGraphs.iterator();
while( it.hasNext() ) {
SpecializedGraph sg = (SpecializedGraph) it.next();
sg.close();
}
m_specializedGraphs = null;
}
}
/**
* Remove this Graph entirely from the database.
*
* This operation is unique to GraphRDB - it removes all
* mention of this graph from the database - after removing
* a graph it is recommended to immediately call close()
* (there is no other useful operation that may be
* performed, and so no reason to keep the Graph around).
*/
public synchronized void remove() {
checkOpen();
// First we ask the driver to remove the specialized graphs
m_driver.removeSpecializedGraphs( m_properties, m_specializedGraphs );
m_properties = null;
m_specializedGraphs = null;
}
/**
* Remove all statements from this graph.
*/
public synchronized void clear() {
if( m_specializedGraphs != null) {
Iterator it = m_specializedGraphs.iterator();
while( it.hasNext() ) {
SpecializedGraph sg = (SpecializedGraph) it.next();
sg.clear();
}
}
}
/**
* Return the connection
*
* @return IDBConnection for the database on which this graph is stored.
* Returns null if the connection has not yet been estabilished.
*/
public IDBConnection getConnection() {
if( m_driver == null )
return null;
return m_driver.getConnection();
}
/**
* Return the reification behavior (GraphRDB) for this graph
*
* @return integer that defines the reification behavior for this graphRDB.
*/
public int reificationBehavior( )
{
return m_reificationBehaviour;
}
/**
* Return an iterator over the specialized graphs for this graph
*
* @return Iterator over the list of specialized graphs.
*/
public Iterator getSpecializedGraphs() {
return m_specializedGraphs.iterator();
}
private DBQueryHandler q = null;
/* (non-Javadoc)
* @see com.hp.hpl.jena.graph.Graph#queryHandler()
*/
public QueryHandler queryHandler()
{
if (q == null) q = new DBQueryHandler( this);
return q;
}
public DBQueryHandler DBqueryHandler()
{
if (q == null) queryHandler();
return q;
}
/**
* Get the value of DoDuplicateCheck
* @return bool boolean
*/
public boolean getDoDuplicateCheck() {
return m_driver.getDoDuplicateCheck();
}
/**
* Set the value of DoDuplicateCheck.
* @param bool boolean
*/
public void setDoDuplicateCheck(boolean bool) {
m_driver.setDoDuplicateCheck(bool);
boolean nb = !bool;
if (isOpen()) {
Iterator it = m_specializedGraphs.iterator();
while (it.hasNext()) {
SpecializedGraph sg = (SpecializedGraph) it.next();
sg.getPSet().setSkipDuplicateCheck(nb);
}
}
}
/**
* Set the value of DoFastpath.
* @param val boolean
*/
public void setDoFastpath ( boolean val ) {
DBqueryHandler().setDoFastpath(val);
}
/**
* Get the value of DoFastpath.
* @return boolean
*/
public boolean getDoFastpath () {
return DBqueryHandler().getDoFastpath();
}
/**
* Set the value of QueryOnlyAsserted.
* @param opt boolean
*/
public void setQueryOnlyAsserted ( boolean opt ) {
if ( opt ) {
m_specializedGraphs = m_specializedGraphAsserted;
DBqueryHandler().setQueryOnlyReified(false);
} else
m_specializedGraphs = m_specializedGraphsAll;
DBqueryHandler().setQueryOnlyAsserted(opt);
}
/**
* Get the value of QueryOnlyAsserted.
* @return boolean
*/
public boolean getQueryOnlyAsserted() {
return DBqueryHandler().getQueryOnlyAsserted();
}
/**
* Set the value of QueryOnlyReified.
* @param opt boolean
*/
public void setQueryOnlyReified ( boolean opt ) {
if ( opt ) {
m_specializedGraphs = m_specializedGraphReifiers;
DBqueryHandler().setQueryOnlyAsserted(false);
} else {
m_specializedGraphs = m_specializedGraphsAll;
}
DBqueryHandler().setQueryOnlyReified(opt);
}
/**
* Get the value of QueryOnlyReified.
* @return boolean
*/
public boolean getQueryOnlyReified() {
return DBqueryHandler().getQueryOnlyReified();
}
/**
* Set the value of QueryFullReified.
* @param opt boolean
*/
public void setQueryFullReified ( boolean opt ) {
DBqueryHandler().setQueryFullReified(opt);
}
/**
* Get the value of QueryFullReified.
* @return boolean
*/
public boolean getQueryFullReified() {
return DBqueryHandler().getQueryFullReified();
}
/**
* Set the value of DoImplicitJoin.
* @param val boolean
*/
public void setDoImplicitJoin ( boolean val ) {
DBqueryHandler().setDoImplicitJoin(val);
}
}
/*
* (c) Copyright 2002, 2003, 2004, 2005, 2006, 2007 Hewlett-Packard Development Company, LP
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -