balld 01/07/04 21:32:29
Modified: src/org/apache/cocoon/components/language/markup/xsp/java
esql.xsl
Log:
patch from torsten curdt to make no-results/results mutually exclusive
Revision Changes Path
1.8 +25 -20
xml-cocoon2/src/org/apache/cocoon/components/language/markup/xsp/java/esql.xsl
Index: esql.xsl
===================================================================
RCS file:
/home/cvs/xml-cocoon2/src/org/apache/cocoon/components/language/markup/xsp/java/esql.xsl,v
retrieving revision 1.7
retrieving revision 1.8
diff -u -r1.7 -r1.8
--- esql.xsl 2001/06/19 19:56:33 1.7
+++ esql.xsl 2001/07/05 04:32:29 1.8
@@ -1,5 +1,5 @@
<?xml version="1.0"?>
-<!-- $Id: esql.xsl,v 1.7 2001/06/19 19:56:33 bloritsch Exp $-->
+<!-- $Id: esql.xsl,v 1.8 2001/07/05 04:32:29 balld Exp $-->
<!--
============================================================================
@@ -502,20 +502,28 @@
</xsl:otherwise>
</xsl:choose>
if (_esql_query.results) {
- _esql_query.resultset = _esql_query.statement.getResultSet();
- _esql_query.resultset_metadata = _esql_query.resultset.getMetaData();
- _esql_query.position = 0;
- if (_esql_connection.use_limit_clause == 0 && _esql_query.skip_rows
> 0) {
- while (_esql_query.resultset.next()) {
- _esql_query.position++;
- if (_esql_query.position == _esql_query.skip_rows) {
- break;
+ do {
+ _esql_query.resultset = _esql_query.statement.getResultSet();
+ _esql_query.resultset_metadata = _esql_query.resultset.getMetaData();
+ _esql_query.position = 0;
+ if (_esql_connection.use_limit_clause == 0 &&
_esql_query.skip_rows > 0) {
+ while (_esql_query.resultset.next()) {
+ _esql_query.position++;
+ if (_esql_query.position == _esql_query.skip_rows) {
+ break;
+ }
}
}
- }
- <xsl:apply-templates select="esql:results"/>
- <xsl:apply-templates select="esql:no-results"/>
- _esql_query.resultset.close();
+
+ if (_esql_query.resultset.next()) { /* desire */
+ <xsl:apply-templates select="esql:results"/>
+ }
+ else {
+ <xsl:apply-templates select="esql:no-results"/>
+ }
+
+ _esql_query.resultset.close();
+ } while(_esql_query.statement.getMoreResults());
} else {
_esql_query.position = _esql_query.statement.getUpdateCount();
if (_esql_query.position >= 0) {
@@ -562,11 +570,7 @@
</xsl:template>
<xsl:template match="esql:execute-query//esql:no-results">
- <xsp:logic>
- if (_esql_query.position == _esql_query.skip_rows) {
- <xsl:apply-templates/>
- }
- </xsp:logic>
+ <xsl:apply-templates/>
</xsl:template>
<xsl:template match="esql:update-results//esql:get-update-count">
@@ -575,14 +579,15 @@
<xsl:template match="esql:results//esql:row-results">
<xsp:logic>
- while (_esql_query.resultset.next()) {
+ do {
<xsl:apply-templates/>
if (_esql_connection.use_limit_clause == 0 && _esql_query.max_rows !=
-1 && _esql_query.position - _esql_query.skip_rows == _esql_query.max_rows-1) {
_esql_query.position++;
break;
}
_esql_query.position++;
- }
+ } while (_esql_query.resultset.next());
+
if (_esql_query.resultset.next()) {
<xsl:apply-templates select="following-sibling::esql:more-results"
mode="more"/>
_esql_query.position++;
----------------------------------------------------------------------
In case of troubles, e-mail: [EMAIL PROTECTED]
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]