when result descriptor count doesn't match result column count, truncate result descriptors

git-svn-id: https://svn.apache.org/repos/asf/tuscany/das-java/trunk@1084336 13f79535-47bb-0310-9956-ffa450edef68
diff --git a/rdb/src/main/java/org/apache/tuscany/das/rdb/impl/ReadCommandImpl.java b/rdb/src/main/java/org/apache/tuscany/das/rdb/impl/ReadCommandImpl.java
index c78d91e..7d3567a 100644
--- a/rdb/src/main/java/org/apache/tuscany/das/rdb/impl/ReadCommandImpl.java
+++ b/rdb/src/main/java/org/apache/tuscany/das/rdb/impl/ReadCommandImpl.java
@@ -20,6 +20,8 @@
 
 import java.io.IOException;
 import java.io.OutputStream;
+import java.sql.ResultSet;
+import java.sql.ResultSetMetaData;
 import java.sql.SQLException;
 import java.util.ArrayList;
 import java.util.Iterator;
@@ -272,8 +274,21 @@
 
         boolean success = false;
         try {
+        	// execute query
             List results = statement.executeQuery(parameters);
             success = true;
+            // if result set contains less columns than result descriptors, crop result descriptors
+            if (resultDescriptors != null && results.size() > 0) {
+            	ResultSet resultSet = (ResultSet) results.get(0);
+            	ResultSetMetaData resultSetMetadata = resultSet.getMetaData();
+            	int columnCount = resultSetMetadata.getColumnCount();
+            	int resultDescriptorCount = resultDescriptors.size();
+            	if (resultDescriptorCount > columnCount) {
+            		resultDescriptors = resultDescriptors.subList(0, columnCount);
+                	refreshResultSetShape();
+            	}
+            }
+            // build graph
             return buildGraph(results);
         } catch (SQLException e) {
             throw new RuntimeException(e);