All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.jena.tdb.store.DatasetGraphTDB Maven / Gradle / Ivy

Go to download

TDB is a storage subsystem for Jena and ARQ, it is a native triple store providing persistent storage of triples/quads.

There is a newer version: 4.10.0
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.apache.jena.tdb.store;


import static org.apache.jena.sparql.util.graph.GraphUtils.triples2quadsDftGraph ;

import java.util.Iterator ;

import org.apache.jena.atlas.iterator.Iter ;
import org.apache.jena.atlas.lib.Closeable ;
import org.apache.jena.atlas.lib.Sync ;
import org.apache.jena.atlas.lib.tuple.Tuple ;
import org.apache.jena.graph.Graph ;
import org.apache.jena.graph.Node ;
import org.apache.jena.query.ReadWrite ;
import org.apache.jena.sparql.core.DatasetGraphTriplesQuads ;
import org.apache.jena.sparql.core.Quad ;
import org.apache.jena.sparql.core.Transactional ;
import org.apache.jena.sparql.core.TransactionalNotSupported ;
import org.apache.jena.sparql.engine.optimizer.reorder.ReorderTransformation ;
import org.apache.jena.tdb.base.file.Location ;
import org.apache.jena.tdb.lib.NodeLib ;
import org.apache.jena.tdb.store.nodetupletable.NodeTupleTable ;
import org.apache.jena.tdb.transaction.DatasetGraphTransaction ;
import org.apache.jena.tdb.transaction.DatasetGraphTxn ;

/** This is the class that creates a dataset over the storage. 
 *  The name is historical. "{@code TDBStorage}" might be better nowadays. 
 * 

This class is not {@code Transactional}. It is used within the TDB transaction system. *

* See also: *

    *
  • {@link DatasetGraphTxn} – the sublcass that provides a single tranasaction
  • *
  • {@link DatasetGraphTransaction} – class that provides the application with the right DatasetGraphTDB (base or transaction).
  • *
*/ final public class DatasetGraphTDB extends DatasetGraphTriplesQuads implements /*DatasetGraph,*/ Sync, Closeable { private TripleTable tripleTable ; private QuadTable quadTable ; private DatasetPrefixesTDB prefixes ; private final ReorderTransformation transform ; private final StorageConfig config ; private boolean closed = false ; public DatasetGraphTDB(TripleTable tripleTable, QuadTable quadTable, DatasetPrefixesTDB prefixes, ReorderTransformation transform, StorageConfig config) { this.tripleTable = tripleTable ; this.quadTable = quadTable ; this.prefixes = prefixes ; this.transform = transform ; this.config = config ; } public QuadTable getQuadTable() { return quadTable ; } public TripleTable getTripleTable() { return tripleTable ; } @Override protected Iterator findInDftGraph(Node s, Node p, Node o) { return triples2quadsDftGraph(getTripleTable().find(s, p, o)) ; } @Override protected Iterator findInSpecificNamedGraph(Node g, Node s, Node p, Node o) { return getQuadTable().find(g, s, p, o) ; } @Override protected Iterator findInAnyNamedGraphs(Node s, Node p, Node o) { return getQuadTable().find(Node.ANY, s, p, o) ; } @Override protected void addToDftGraph(Node s, Node p, Node o) { getTripleTable().add(s,p,o) ; } @Override protected void addToNamedGraph(Node g, Node s, Node p, Node o) { getQuadTable().add(g, s, p, o) ; } @Override protected void deleteFromDftGraph(Node s, Node p, Node o) { getTripleTable().delete(s,p,o) ; } @Override protected void deleteFromNamedGraph(Node g, Node s, Node p, Node o) { getQuadTable().delete(g, s, p, o) ; } public GraphNonTxnTDB getDefaultGraphTDB() { return (GraphNonTxnTDB)getDefaultGraph() ; } public GraphNonTxnTDB getGraphTDB(Node graphNode) { return (GraphNonTxnTDB)getGraph(graphNode) ; } @Override public void close() { if ( closed ) return ; closed = true ; tripleTable.close() ; quadTable.close() ; prefixes.close(); // Which will cause reuse to throw exceptions early. tripleTable = null ; quadTable = null ; prefixes = null ; } @Override // Empty graphs don't "exist" public boolean containsGraph(Node graphNode) { if ( Quad.isDefaultGraph(graphNode) || Quad.isUnionGraph(graphNode) ) return true ; // Have to look explicitly, which is a bit of a nuisance. // But does not normally happen for GRAPH because that's rewritten to quads. // Only pattern with complex paths go via GRAPH. Iterator> x = quadTable.getNodeTupleTable().findAsNodeIds(graphNode, null, null, null) ; if ( x == null ) return false ; // NodeId graphNodeId = quadTable.getNodeTupleTable().getNodeTable().getNodeIdForNode(graphNode) ; // Tuple pattern = Tuple.create(graphNodeId, null, null, null) ; // Iterator> x = quadTable.getNodeTupleTable().getTupleTable().find(pattern) ; boolean result = x.hasNext() ; return result ; } // When not yet transactional, these can be called?? @Override public Graph getDefaultGraph() { return new GraphNonTxnTDB(this, null) ; } @Override public Graph getGraph(Node graphNode) { return new GraphNonTxnTDB(this, graphNode) ; } @Override public void removeGraph(Node graphNode) { deleteAny(graphNode, Node.ANY, Node.ANY, Node.ANY) ; if ( graphNode.isURI() ) getPrefixes().removeAllFromPrefixMap(graphNode.getURI()); } public StorageConfig getConfig() { return config ; } public ReorderTransformation getReorderTransform() { return transform ; } public DatasetPrefixesTDB getPrefixes() { return prefixes ; } @Override public Iterator listGraphNodes() { Iterator> x = quadTable.getNodeTupleTable().findAll() ; Iterator z = Iter.iter(x).map(t -> t.get(0)).distinct() ; return NodeLib.nodes(quadTable.getNodeTupleTable().getNodeTable(), z) ; } @Override public long size() { return Iter.count(listGraphNodes()) ; } @Override public boolean isEmpty() { return getTripleTable().isEmpty() && getQuadTable().isEmpty() ; } @Override public void clear() { // Leave the node table alone. getTripleTable().clearTriples() ; getQuadTable().clearQuads() ; } public NodeTupleTable chooseNodeTupleTable(Node graphNode) { if ( graphNode == null || Quad.isDefaultGraph(graphNode) ) return getTripleTable().getNodeTupleTable() ; else // Includes Node.ANY and union graph return getQuadTable().getNodeTupleTable() ; } private static final int sliceSize = 1000 ; @Override public void deleteAny(Node g, Node s, Node p, Node o) { // Delete in batches. // That way, there is no active iterator when a delete // from the indexes happens. NodeTupleTable t = chooseNodeTupleTable(g) ; @SuppressWarnings("unchecked") Tuple[] array = (Tuple[])new Tuple[sliceSize] ; while (true) { // Convert/cache s,p,o? // The Node Cache will catch these so don't worry unduely. Iterator> iter = null ; if ( g == null ) iter = t.findAsNodeIds(s, p, o) ; else iter = t.findAsNodeIds(g, s, p, o) ; if ( iter == null ) // Finished? return ; // Get a slice int len = 0 ; for (; len < sliceSize; len++) { if ( !iter.hasNext() ) break ; array[len] = iter.next() ; } // Delete them. for (int i = 0; i < len; i++) { t.getTupleTable().delete(array[i]) ; array[i] = null ; } // Finished? if ( len < sliceSize ) break ; } } public Location getLocation() { return config.location ; } @Override public void sync() { tripleTable.sync() ; quadTable.sync() ; prefixes.sync() ; } @Override public void setDefaultGraph(Graph g) { throw new UnsupportedOperationException("Can't set default graph via GraphStore on a TDB-backed dataset") ; } private final Transactional txn = new TransactionalNotSupported() ; @Override public void begin(ReadWrite mode) { txn.begin(mode) ; } @Override public void commit() { txn.commit() ; } @Override public void abort() { txn.abort() ; } @Override public boolean isInTransaction() { return txn.isInTransaction() ; } @Override public void end() { txn.end(); } @Override public boolean supportsTransactions() { return true ; } @Override public boolean supportsTransactionAbort() { return false ; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy