Revision 706
Added by bojilova almost 24 years ago
src/edu/ucsb/nceas/metacat/QuerySpecification.java | ||
---|---|---|
134 | 134 |
QuerySpecification qspec = |
135 | 135 |
new QuerySpecification(xml, util.getOption("saxparser"), |
136 | 136 |
util.getOption("accNumberSeparator")); |
137 |
System.out.println(qspec.printSQL()); |
|
137 |
boolean useXMLIndex = false; |
|
138 |
System.out.println(qspec.printSQL(useXMLIndex)); |
|
138 | 139 |
|
139 | 140 |
} catch (IOException e) { |
140 | 141 |
System.err.println(e.getMessage()); |
... | ... | |
289 | 290 |
/** |
290 | 291 |
* create a SQL serialization of the query that this instance represents |
291 | 292 |
*/ |
292 |
public String printSQL() { |
|
293 |
public String printSQL(boolean useXMLIndex) {
|
|
293 | 294 |
StringBuffer self = new StringBuffer(); |
294 | 295 |
|
295 | 296 |
self.append("SELECT docid,docname,doctype,"); |
... | ... | |
297 | 298 |
self.append("FROM xml_documents WHERE docid IN ("); |
298 | 299 |
|
299 | 300 |
// This determines the documents that meet the query conditions |
300 |
self.append(query.printSQL()); |
|
301 |
self.append(query.printSQL(useXMLIndex));
|
|
301 | 302 |
|
302 | 303 |
self.append(") "); |
303 | 304 |
|
... | ... | |
556 | 557 |
/** |
557 | 558 |
* create a SQL serialization of the query that this instance represents |
558 | 559 |
*/ |
559 |
public String printSQL() { |
|
560 |
public String printSQL(boolean useXMLIndex) {
|
|
560 | 561 |
StringBuffer self = new StringBuffer(); |
561 | 562 |
boolean first = true; |
562 | 563 |
|
... | ... | |
572 | 573 |
} |
573 | 574 |
if (qobject instanceof QueryGroup) { |
574 | 575 |
QueryGroup qg = (QueryGroup)qobject; |
575 |
self.append(qg.printSQL()); |
|
576 |
self.append(qg.printSQL(useXMLIndex));
|
|
576 | 577 |
} else if (qobject instanceof QueryTerm) { |
577 | 578 |
QueryTerm qt = (QueryTerm)qobject; |
578 |
self.append(qt.printSQL()); |
|
579 |
self.append(qt.printSQL(useXMLIndex));
|
|
579 | 580 |
} else { |
580 | 581 |
System.err.println("qobject wrong type: fatal error"); |
581 | 582 |
} |
... | ... | |
664 | 665 |
/** |
665 | 666 |
* create a SQL serialization of the query that this instance represents |
666 | 667 |
*/ |
667 |
public String printSQL() { |
|
668 |
public String printSQL(boolean useXMLIndex) {
|
|
668 | 669 |
StringBuffer self = new StringBuffer(); |
669 | 670 |
|
670 | 671 |
// Uppercase the search string if case match is not important |
... | ... | |
696 | 697 |
if (pathexpr != null) { |
697 | 698 |
self.append(nodedataterm + " LIKE " + "'" + searchvalue + "' "); |
698 | 699 |
self.append("AND parentnodeid IN "); |
699 |
self.append("(SELECT nodeid FROM xml_index WHERE path LIKE " + |
|
700 |
"'" + pathexpr + "') " ); |
|
700 |
// use XML Index |
|
701 |
if ( useXMLIndex ) { |
|
702 |
self.append("(SELECT nodeid FROM xml_index WHERE path LIKE " + |
|
703 |
"'" + pathexpr + "') " ); |
|
704 |
// without using XML Index; using nested statements instead |
|
705 |
} else { |
|
706 |
self.append(useNestedStatements(pathexpr)); |
|
707 |
} |
|
701 | 708 |
} else { |
702 | 709 |
self.append(nodedataterm + " LIKE " + "'" + searchvalue + "' "); |
703 | 710 |
} |
... | ... | |
705 | 712 |
return self.toString(); |
706 | 713 |
} |
707 | 714 |
|
715 |
/* |
|
716 |
* Constraint the query with @pathexp without using the XML Index, |
|
717 |
* but nested SQL statements instead. The query migth be slower. |
|
718 |
*/ |
|
719 |
private String useNestedStatements(String pathexpr) |
|
720 |
{ |
|
721 |
StringBuffer nestedStmts = new StringBuffer(); |
|
722 |
Vector nodes = new Vector(); |
|
723 |
String path = pathexpr; |
|
724 |
int inx = 0; |
|
725 |
|
|
726 |
do { |
|
727 |
inx = path.lastIndexOf("/"); |
|
728 |
//System.out.println(path.substring(inx+1)); |
|
729 |
nodes.addElement(path.substring(inx+1)); |
|
730 |
path = path.substring(0, Math.abs(inx)); |
|
731 |
} while ( inx > 0 ); |
|
732 |
|
|
733 |
// nested statements |
|
734 |
int i = 0; |
|
735 |
for (i = 0; i < nodes.size()-1; i++) { |
|
736 |
nestedStmts.append("(SELECT nodeid FROM xml_nodes" + |
|
737 |
" WHERE nodename LIKE '" + |
|
738 |
(String)nodes.elementAt(i) + "'" + |
|
739 |
" AND parentnodeid IN "); |
|
740 |
} |
|
741 |
// for the last statement: it is without " AND parentnodeid IN " |
|
742 |
nestedStmts.append("(SELECT nodeid FROM xml_nodes" + |
|
743 |
" WHERE nodename LIKE '" + |
|
744 |
(String)nodes.elementAt(i) + "'" ); |
|
745 |
// node.size() number of closing brackets |
|
746 |
for (i = 0; i < nodes.size(); i++) { |
|
747 |
nestedStmts.append(")"); |
|
748 |
} |
|
749 |
|
|
750 |
|
|
751 |
//System.out.println(nestedStmts.toString()); |
|
752 |
return nestedStmts.toString(); |
|
753 |
} |
|
754 |
|
|
708 | 755 |
/** |
709 | 756 |
* create a String description of the query that this instance represents. |
710 | 757 |
* This should become a way to get the XML serialization of the query. |
711 | 758 |
*/ |
712 |
public String toString() { |
|
759 |
public String toString(boolean useXMLIndex) {
|
|
713 | 760 |
|
714 |
return this.printSQL(); |
|
761 |
return this.printSQL(useXMLIndex);
|
|
715 | 762 |
} |
716 | 763 |
} |
717 | 764 |
} |
src/edu/ucsb/nceas/metacat/DBQuery.java | ||
---|---|---|
39 | 39 |
import java.util.Stack; |
40 | 40 |
import java.util.Hashtable; |
41 | 41 |
import java.util.Enumeration; |
42 |
import java.io.File; |
|
43 |
import java.io.FileWriter; |
|
44 |
import java.io.BufferedWriter; |
|
42 | 45 |
|
43 | 46 |
/** |
44 | 47 |
* A Class that searches a relational DB for elements and |
... | ... | |
68 | 71 |
if (args.length < 1) |
69 | 72 |
{ |
70 | 73 |
System.err.println("Wrong number of arguments!!!"); |
71 |
System.err.println("USAGE: java DBQuery <xmlfile>"); |
|
74 |
System.err.println("USAGE: java DBQuery [-t] [-index] <xmlfile>");
|
|
72 | 75 |
return; |
73 | 76 |
} else { |
74 | 77 |
try { |
75 |
|
|
76 |
String xmlfile = args[0]; |
|
77 | 78 |
|
79 |
int i = 0; |
|
80 |
boolean showRuntime = false; |
|
81 |
boolean useXMLIndex = false; |
|
82 |
if ( args[i].equals( "-t" ) ) { |
|
83 |
showRuntime = true; |
|
84 |
i++; |
|
85 |
} |
|
86 |
if ( args[i].equals( "-index" ) ) { |
|
87 |
useXMLIndex = true; |
|
88 |
i++; |
|
89 |
} |
|
90 |
String xmlfile = args[i]; |
|
91 |
|
|
92 |
// Time the request if asked for |
|
93 |
double startTime = System.currentTimeMillis(); |
|
94 |
|
|
78 | 95 |
// Open a connection to the database |
79 | 96 |
MetaCatUtil util = new MetaCatUtil(); |
80 |
double startTime = System.currentTimeMillis(); |
|
81 | 97 |
Connection dbconn = util.openDBConnection(); |
98 |
|
|
82 | 99 |
double connTime = System.currentTimeMillis(); |
100 |
|
|
83 | 101 |
// Execute the query |
84 | 102 |
DBQuery queryobj = new DBQuery(dbconn, util.getOption("saxparser")); |
85 | 103 |
FileReader xml = new FileReader(new File(xmlfile)); |
86 | 104 |
Hashtable nodelist = null; |
87 |
nodelist = queryobj.findDocuments(xml, null, null); |
|
88 |
double stopTime = System.currentTimeMillis(); |
|
105 |
nodelist = queryobj.findDocuments(xml, null, null, useXMLIndex);
|
|
106 |
|
|
89 | 107 |
// Print the reulting document listing |
90 | 108 |
StringBuffer result = new StringBuffer(); |
91 | 109 |
String document = null; |
92 | 110 |
String docid = null; |
93 | 111 |
result.append("<?xml version=\"1.0\"?>\n"); |
94 | 112 |
result.append("<resultset>\n"); |
95 |
// following line removed by Dan Higgins to avoid insertion of |
|
96 |
// query XML inside returned XML doc |
|
97 |
//result.append(" <query>" + xmlfile + "</query>\n"); |
|
113 |
// following line removed by Dan Higgins to avoid insertion of query XML inside returned XML doc |
|
114 |
// result.append(" <query>" + xmlfile + "</query>\n"); |
|
98 | 115 |
Enumeration doclist = nodelist.keys(); |
99 | 116 |
while (doclist.hasMoreElements()) { |
100 | 117 |
docid = (String)doclist.nextElement(); |
... | ... | |
104 | 121 |
} |
105 | 122 |
result.append("</resultset>\n"); |
106 | 123 |
|
107 |
System.out.println(result);
|
|
108 |
|
|
124 |
// Time the request if asked for
|
|
125 |
double stopTime = System.currentTimeMillis(); |
|
109 | 126 |
double dbOpenTime = (connTime - startTime)/1000; |
110 |
double insertTime = (stopTime - connTime)/1000;
|
|
127 |
double readTime = (stopTime - connTime)/1000;
|
|
111 | 128 |
double executionTime = (stopTime - startTime)/1000; |
112 |
System.out.println("\n\nTotal Execution time was: " + |
|
113 |
executionTime + " seconds."); |
|
114 |
System.out.println("Time to open DB connection was: " + dbOpenTime + |
|
115 |
" seconds."); |
|
116 |
System.out.println("Time to perform query was: " + insertTime + |
|
117 |
" seconds."); |
|
118 |
|
|
129 |
if (showRuntime) { |
|
130 |
System.out.println("\n\nTotal Execution time was: " + |
|
131 |
executionTime + " seconds."); |
|
132 |
System.out.println("Time to open DB connection was: " + dbOpenTime + |
|
133 |
" seconds."); |
|
134 |
System.out.println("Time to read was: " + readTime + |
|
135 |
" seconds."); |
|
136 |
} |
|
137 |
//System.out.println(result); |
|
138 |
//write into a file "result.txt" |
|
139 |
File f = new File("./result.txt"); |
|
140 |
FileWriter fw = new FileWriter(f); |
|
141 |
BufferedWriter out = new BufferedWriter(fw); |
|
142 |
out.write(result.toString()); |
|
143 |
out.flush(); |
|
144 |
out.close(); |
|
145 |
fw.close(); |
|
146 |
|
|
119 | 147 |
} catch (Exception e) { |
120 | 148 |
System.err.println("Error in DBQuery.main"); |
121 | 149 |
System.err.println(e.getMessage()); |
... | ... | |
142 | 170 |
this.parserName = parserName; |
143 | 171 |
} |
144 | 172 |
|
145 |
public Hashtable findDocuments(Reader xmlquery, String user, String group) |
|
173 |
public Hashtable findDocuments(Reader xmlquery, String user, String group, |
|
174 |
boolean useXMLIndex) |
|
146 | 175 |
{ |
147 |
return findDocuments(xmlquery, user, group, null); |
|
176 |
return findDocuments(xmlquery, user, group, null, useXMLIndex);
|
|
148 | 177 |
} |
149 | 178 |
|
179 |
public Hashtable findDocuments(Reader xmlquery, String user, String group, |
|
180 |
String[] returndoc) |
|
181 |
{ |
|
182 |
return findDocuments(xmlquery, user, group, returndoc, true); |
|
183 |
} |
|
184 |
|
|
150 | 185 |
/** |
151 | 186 |
* routine to search the elements and attributes looking to match query |
152 | 187 |
* |
... | ... | |
156 | 191 |
* @param returndoc an array of document types to backtrack against. |
157 | 192 |
*/ |
158 | 193 |
public Hashtable findDocuments(Reader xmlquery, String user, String group, |
159 |
String[] returndoc) |
|
194 |
String[] returndoc, boolean useXMLIndex)
|
|
160 | 195 |
{ |
161 | 196 |
//System.out.println("in finddocuments"); |
162 | 197 |
Hashtable docListResult = new Hashtable(); |
... | ... | |
191 | 226 |
parserName, |
192 | 227 |
util.getOption("accNumSeparator")); |
193 | 228 |
// System.out.println(qspec.printSQL()); |
194 |
pstmt = dbconn.prepareStatement( qspec.printSQL() ); |
|
229 |
pstmt = dbconn.prepareStatement( qspec.printSQL(useXMLIndex) );
|
|
195 | 230 |
|
196 | 231 |
// Execute the SQL query using the JDBC connection |
197 | 232 |
pstmt.execute(); |
Also available in: Unified diff
included flag in DBQuery to run pathqueries with or without the index,
but for the command line only.