
prerna.rdf.engine.wrappers.RawJenaSelectWrapper Maven / Gradle / Ivy
The newest version!
package prerna.rdf.engine.wrappers;
import java.io.IOException;
import java.util.List;
import java.util.Set;
import org.apache.jena.query.QuerySolution;
import org.apache.jena.query.ResultSet;
import org.apache.jena.rdf.model.RDFNode;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.openrdf.query.parser.ParsedQuery;
import org.openrdf.query.parser.sparql.SPARQLParser;
import prerna.algorithm.api.SemossDataType;
import prerna.auth.User;
import prerna.engine.api.IHeadersDataRow;
import prerna.engine.api.IRawSelectWrapper;
import prerna.om.HeadersDataRow;
import prerna.om.ThreadStore;
import prerna.usertracking.UserQueryTrackingThread;
import prerna.util.Constants;
import prerna.util.Utility;
public class RawJenaSelectWrapper extends AbstractWrapper implements IRawSelectWrapper {
private static final Logger classLogger = LogManager.getLogger(RawJenaSelectWrapper.class);
private ResultSet rs = null;
@Override
public void execute() throws Exception {
rs = (ResultSet) engine.execQuery(query);
// set the variables for future use
setVariables();
}
@Override
public boolean hasNext() {
return rs.hasNext();
}
@Override
public IHeadersDataRow next() {
// need to store both the clean and raw values
Object[] cleanRow = new Object[numColumns];
Object[] rawRow = new Object[numColumns];
QuerySolution row = rs.next();
for(int colIndex = 0;colIndex < numColumns; colIndex++) {
RDFNode node = row.get(rawHeaders[colIndex]);
// raw value is the straight return from the binding set
rawRow[colIndex] = node.toString();
// get the real value of the node
cleanRow[colIndex] = getRealValue(node);
}
return new HeadersDataRow(headers, cleanRow, rawRow);
}
private void setVariables() {
// this makes the assumption that the query is constructed
// using the logic within the SPARQL Query Builder
// get the vars from the tuple result
List names = rs.getResultVars();
numColumns = names.size();
// what should be in physical names?
// we technically need the concept and prop name
// this is already what we have via the names binding
// when it is created through query builder
rawHeaders = names.toArray(new String[names.size()]);
headers = new String[numColumns];
for(int colIndex = 0; colIndex < numColumns; colIndex++){
// for the display, if we encounter a "__", we want to
// split and get the second part of the string
// that is the display for the column
String columnLabel = names.get(colIndex);
if(columnLabel.contains("__")){
String[] splitColAndTable = columnLabel.split("__");
columnLabel = splitColAndTable[1];
}
headers[colIndex] = columnLabel;
}
}
@Override
public String[] getHeaders() {
return headers;
}
private Object getRealValue(RDFNode node){
if(node.isAnon()) {
classLogger.debug("Ok.. an anon node");
return Utility.getNextID();
} else {
classLogger.debug("Raw data JENA For Column ");
return Utility.getInstanceName(node + "");
}
}
@Override
public SemossDataType[] getTypes() {
if(this.types == null) {
try {
SPARQLParser parser = new SPARQLParser();
ParsedQuery parsedQuery = parser.parseQuery(query, null);
CustomSparqlAggregationParser aggregationVisitor = new CustomSparqlAggregationParser();
parsedQuery.getTupleExpr().visit(aggregationVisitor);
Set aggregationValues = aggregationVisitor.getValue();
this.types = new SemossDataType[this.numColumns];
for(int i = 0; i < this.numColumns; i++) {
if(aggregationValues.contains(this.rawHeaders[i])) {
this.types[i] = SemossDataType.DOUBLE;
} else {
this.types[i] = SemossDataType.STRING;
}
}
} catch (Exception e) {
classLogger.error(Constants.STACKTRACE, e);
this.types = new SemossDataType[this.numColumns];
for(int i = 0; i < this.numColumns; i++) {
this.types[i] = SemossDataType.STRING;
}
}
}
return this.types;
}
@Override
public void close() throws IOException {
}
@Override
public long getNumRows() {
if(this.numRows == 0) {
User user = ThreadStore.getUser();
UserQueryTrackingThread queryT = new UserQueryTrackingThread(user, this.engine.getEngineId());
String query = "select count(*) where { " + this.query + "}";
ResultSet resultSet = null;
try {
queryT.setQuery(query);
queryT.setStartTimeNow();
resultSet = (ResultSet) engine.execQuery(query);
queryT.setEndTimeNow();
if(resultSet != null && resultSet.hasNext()) {
QuerySolution row = resultSet.next();
RDFNode node = row.get("count");
Object cleanValue = getRealValue(node);
if(cleanValue instanceof Number) {
this.numRows = ((Number) cleanValue).longValue();
}
}
} catch (Exception e) {
queryT.setFailed();
classLogger.error(Constants.STACKTRACE, e);
} finally {
new Thread(queryT).start();
}
}
return this.numRows;
}
@Override
public long getNumRecords() {
return getNumRows() * this.numColumns;
}
@Override
public void reset() throws Exception {
close();
execute();
}
@Override
public boolean flushable() {
return false;
}
@Override
public String flush() {
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy