Changeset: 640b5b25fda9 for MonetDB
URL: http://dev.monetdb.org/hg/MonetDB?cmd=changeset;node=640b5b25fda9
Modified Files:
        sql/src/server/bin_optimizer.c
        sql/src/server/rel_bin.c
Branch: default
Log Message:

Merge with Oct2010 branch.


diffs (truncated from 308 to 300 lines):

diff -r cad11c6e3bb7 -r 640b5b25fda9 java/tests/Makefile.ag
--- a/java/tests/Makefile.ag    Wed Oct 13 10:03:23 2010 +0200
+++ b/java/tests/Makefile.ag    Wed Oct 13 14:31:44 2010 +0200
@@ -22,6 +22,7 @@
                Test_Creplysize.java \
                Test_Csavepoints.java \
                Test_Ctransaction.java \
+               Test_PSgeneratedkeys.java \
                Test_PStimedate.java \
                Test_PStimezone.java \
                Test_PStypes.java \
diff -r cad11c6e3bb7 -r 640b5b25fda9 java/tests/Test_PSgeneratedkeys.java
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/java/tests/Test_PSgeneratedkeys.java      Wed Oct 13 14:31:44 2010 +0200
@@ -0,0 +1,78 @@
+/*
+ * The contents of this file are subject to the MonetDB Public License
+ * Version 1.1 (the "License"); you may not use this file except in
+ * compliance with the License. You may obtain a copy of the License at
+ * http://monetdb.cwi.nl/Legal/MonetDBLicense-1.1.html
+ *
+ * Software distributed under the License is distributed on an "AS IS"
+ * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
+ * License for the specific language governing rights and limitations
+ * under the License.
+ *
+ * The Original Code is the MonetDB Database System.
+ *
+ * The Initial Developer of the Original Code is CWI.
+ * Portions created by CWI are Copyright (C) 1997-July 2008 CWI.
+ * Copyright August 2008-2010 MonetDB B.V.
+ * All Rights Reserved.
+ */
+
+import java.sql.*;
+
+public class Test_PSgeneratedkeys {
+       public static void main(String[] args) throws Exception {
+               Class.forName("nl.cwi.monetdb.jdbc.MonetDriver");
+               Connection con = DriverManager.getConnection(args[0]);
+               Statement stmt = con.createStatement();
+               PreparedStatement pstmt;
+               //ResultSet rs = null;
+               //DatabaseMetaData dbmd = con.getMetaData();
+
+               con.setAutoCommit(false);
+               // >> false: auto commit was just switched off
+               System.out.println("0. false\t" + con.getAutoCommit());
+
+               try {
+                       stmt.executeUpdate(
+"CREATE TABLE psgenkey (" +
+"       id       serial," +
+"       val      varchar(20)" +
+")"
+);
+               } catch (SQLException e) {
+                       System.out.println(e);
+                       System.out.println("Creation of test table failed! :(");
+                       System.out.println("ABORTING TEST!!!");
+                       System.exit(-1);
+               }
+
+               try {
+                       pstmt = con.prepareStatement(
+"INSERT INTO psgenkey (val) VALUES ('this is a test')",
+Statement.RETURN_GENERATED_KEYS
+);
+                       System.out.print("1. inserting a record...");
+
+                       pstmt.executeUpdate();
+
+                       System.out.println("success :)");
+
+                       // now get the generated keys
+                       System.out.print("2. getting generated keys...");
+                       ResultSet keys = pstmt.getGeneratedKeys();
+                       if (keys == null || !keys.next()) {
+                               System.out.println("there are no keys! :(");
+                               System.out.println("ABORTING TEST!!!");
+                               System.exit(-1);
+                       }
+
+                       System.out.println("generated key index: " + 
keys.getInt(1));
+               } catch (SQLException e) {
+                       System.out.println("FAILED :( "+ e.getMessage());
+                       System.out.println("ABORTING TEST!!!");
+               }
+
+               con.rollback();
+               con.close();
+       }
+}
diff -r cad11c6e3bb7 -r 640b5b25fda9 java/tests/build.xml
--- a/java/tests/build.xml      Wed Oct 13 10:03:23 2010 +0200
+++ b/java/tests/build.xml      Wed Oct 13 14:31:44 2010 +0200
@@ -107,6 +107,7 @@
     <antcall target="Test_Creplysize" />
     <antcall target="Test_Csavepoints" />
     <antcall target="Test_Ctransaction" />
+    <antcall target="Test_PSgeneratedkeys" />
     <antcall target="Test_PSlargeresponse" />
     <antcall target="Test_PStimedate" />
     <antcall target="Test_PStimezone" />
@@ -182,6 +183,12 @@
     </antcall>
   </target>
 
+  <target name="Test_PSgeneratedkeys">
+    <antcall target="test_class">
+      <param name="test.class" value="Test_PSgeneratedkeys" />
+    </antcall>
+  </target>
+
   <target name="Test_PSlargeresponse">
     <antcall target="test_class">
       <param name="test.class" value="Test_PSlargeresponse" />
diff -r cad11c6e3bb7 -r 640b5b25fda9 sql/src/jdbc/tests/Tests/All
--- a/sql/src/jdbc/tests/Tests/All      Wed Oct 13 10:03:23 2010 +0200
+++ b/sql/src/jdbc/tests/Tests/All      Wed Oct 13 14:31:44 2010 +0200
@@ -4,6 +4,7 @@
 HAVE_JDBCTESTS?Test_Creplysize
 HAVE_JDBCTESTS?Test_Csavepoints
 HAVE_JDBCTESTS?Test_Ctransaction
+HAVE_JDBCTESTS?Test_PSgeneratedkeys
 HAVE_JDBCTESTS?Test_PStimedate
 HAVE_JDBCTESTS?Test_PStimezone
 HAVE_JDBCTESTS?Test_PStypes
diff -r cad11c6e3bb7 -r 640b5b25fda9 
sql/src/jdbc/tests/Tests/Test_PSgeneratedkeys.SQL.bat
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sql/src/jdbc/tests/Tests/Test_PSgeneratedkeys.SQL.bat     Wed Oct 13 
14:31:44 2010 +0200
@@ -0,0 +1,1 @@
+...@call "%TSTSRCDIR%\Test.SQL.bat" %*
diff -r cad11c6e3bb7 -r 640b5b25fda9 
sql/src/jdbc/tests/Tests/Test_PSgeneratedkeys.SQL.sh
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sql/src/jdbc/tests/Tests/Test_PSgeneratedkeys.SQL.sh      Wed Oct 13 
14:31:44 2010 +0200
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+$TSTSRCDIR/Test.SQL.sh $*
diff -r cad11c6e3bb7 -r 640b5b25fda9 
sql/src/jdbc/tests/Tests/Test_PSgeneratedkeys.stable.err
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sql/src/jdbc/tests/Tests/Test_PSgeneratedkeys.stable.err  Wed Oct 13 
14:31:44 2010 +0200
@@ -0,0 +1,84 @@
+stderr of test 'Test_PSgeneratedkeys` in directory 'src/jdbc/tests` itself:
+
+
+# 10:40:25 >  
+# 10:40:25 >   mserver5 
"--config=/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/etc/monetdb5.conf" 
--debug=10 --set gdk_nr_threads=0 --set 
"monet_mod_path=/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5:/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5/lib:/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5/bin"
 --set 
"gdk_dbfarm=/net/volund.ins.cwi.nl/export/scratch0/fabian/vtmp/mtest-Oct2010-volund.ins.cwi.nl/sql/dbfarm"
  --set mapi_open=true --set xrpc_open=true --set mapi_port=30090 --set 
xrpc_port=46576 --set monet_prompt= --set mal_listing=2 --trace  
"--dbname=mTests_src_jdbc_tests" --set mal_listing=0 ; echo ; echo Over..
+# 10:40:25 >  
+
+# builtin opt  gdk_arch = 64bitx86_64-pc-linux-gnu
+# builtin opt  gdk_version = 1.40.0
+# builtin opt  prefix = /ufs/fabian/scratch/monetdb/Oct2010/program-x86_64
+# builtin opt  exec_prefix = ${prefix}
+# builtin opt  gdk_dbname = demo
+# builtin opt  gdk_dbfarm = ${prefix}/var/MonetDB/dbfarm
+# builtin opt  gdk_debug = 0
+# builtin opt  gdk_alloc_map = no
+# builtin opt  gdk_vmtrim = yes
+# builtin opt  monet_admin = adm
+# builtin opt  monet_prompt = >
+# builtin opt  monet_welcome = yes
+# builtin opt  monet_mod_path = 
/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB
+# builtin opt  monet_daemon = no
+# builtin opt  host = localhost
+# builtin opt  mapi_port = 50000
+# builtin opt  mapi_clients = 2
+# builtin opt  mapi_open = false
+# builtin opt  mapi_autosense = false
+# builtin opt  sql_debug = 0
+# builtin opt  standoff_ns = 
+# builtin opt  standoff_start = start
+# builtin opt  standoff_end = end
+# config opt   prefix = /ufs/fabian/scratch/monetdb/Oct2010/program-x86_64
+# config opt   config = ${prefix}/etc/monetdb5.conf
+# config opt   prefix = /ufs/fabian/scratch/monetdb/Oct2010/program-x86_64
+# config opt   exec_prefix = ${prefix}
+# config opt   gdk_dbfarm = ${prefix}/var/MonetDB5/dbfarm
+# config opt   monet_mod_path = 
/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5:/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5/lib:/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5/bin
+# config opt   mero_pidfile = ${prefix}/var/run/MonetDB/merovingian.pid
+# config opt   mero_controlport = 50001
+# config opt   sql_optimizer = default_pipe
+# config opt   minimal_pipe = inline,remap,deadcode,multiplex,garbageCollector
+# config opt   default_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mitosis,mergetable,deadcode,commonTerms,joinPath,reorder,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   no_mitosis_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,commonTerms,joinPath,reorder,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   sequential_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,commonTerms,joinPath,reorder,deadcode,reduce,history,multiplex,garbageCollector
+# config opt   nov2009_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   replication_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,replication,multiplex,garbageCollector
+# config opt   accumulator_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,accumulators,dataflow,history,multiplex,garbageCollector
+# config opt   recycler_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,deadcode,constants,commonTerms,joinPath,deadcode,recycle,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   cracker_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,selcrack,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   sidcrack_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,sidcrack,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   datacell_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,deadcode,constants,commonTerms,joinPath,datacell,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   octopus_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mitosis,mergetable,deadcode,constants,commonTerms,joinPath,octopus,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   datacyclotron_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,datacyclotron,mergetable,deadcode,commonTerms,joinPath,reorder,deadcode,reduce,dataflow,history,replication,multiplex,garbageCollector
+# config opt   derive_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mitosis,mergetable,deadcode,commonTerms,derivePath,joinPath,reorder,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   dictionary_pipe = 
inline,remap,dictionary,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,history,multiplex,garbageCollector
+# config opt   compression_pipe = 
inline,remap,evaluate,costModel,coercions,emptySet,aliases,mergetable,deadcode,constants,commonTerms,joinPath,deadcode,reduce,dataflow,compression,dataflow,history,multiplex,garbageCollector
+# cmdline opt  config = 
/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/etc/monetdb5.conf
+# cmdline opt  gdk_nr_threads = 0
+# cmdline opt  monet_mod_path = 
/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5:/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5/lib:/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5/bin
+# cmdline opt  gdk_dbfarm = 
/net/volund.ins.cwi.nl/export/scratch0/fabian/vtmp/mtest-Oct2010-volund.ins.cwi.nl/sql/dbfarm
+# cmdline opt  mapi_open = true
+# cmdline opt  xrpc_open = true
+# cmdline opt  mapi_port = 30090
+# cmdline opt  xrpc_port = 46576
+# cmdline opt  monet_prompt = 
+# cmdline opt  mal_listing = 2
+# cmdline opt  gdk_dbname = mTests_src_jdbc_tests
+# cmdline opt  mal_listing = 0
+#warning: please don't forget to set your vault key!
+#(see /ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/etc/monetdb5.conf)
+
+# 10:40:26 >  
+# 10:40:26 >  ./Test_PSgeneratedkeys.SQL.sh Test_PSgeneratedkeys 
+# 10:40:26 >  
+
+
+# 10:40:26 >  
+# 10:40:26 >  java Test_PSgeneratedkeys 
"jdbc:monetdb://volund:30090/mTests_src_jdbc_tests?user=monetdb&password=monetdb"
+# 10:40:26 >  
+
+
+# 10:40:26 >  
+# 10:40:26 >  Done.
+# 10:40:26 >  
+
diff -r cad11c6e3bb7 -r 640b5b25fda9 
sql/src/jdbc/tests/Tests/Test_PSgeneratedkeys.stable.out
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sql/src/jdbc/tests/Tests/Test_PSgeneratedkeys.stable.out  Wed Oct 13 
14:31:44 2010 +0200
@@ -0,0 +1,40 @@
+stdout of test 'Test_PSgeneratedkeys` in directory 'src/jdbc/tests` itself:
+
+
+# 10:40:25 >  
+# 10:40:25 >   mserver5 
"--config=/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/etc/monetdb5.conf" 
--debug=10 --set gdk_nr_threads=0 --set 
"monet_mod_path=/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5:/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5/lib:/ufs/fabian/scratch/monetdb/Oct2010/program-x86_64/lib/MonetDB5/bin"
 --set 
"gdk_dbfarm=/net/volund.ins.cwi.nl/export/scratch0/fabian/vtmp/mtest-Oct2010-volund.ins.cwi.nl/sql/dbfarm"
  --set mapi_open=true --set xrpc_open=true --set mapi_port=30090 --set 
xrpc_port=46576 --set monet_prompt= --set mal_listing=2 --trace  
"--dbname=mTests_src_jdbc_tests" --set mal_listing=0 ; echo ; echo Over..
+# 10:40:25 >  
+
+# MonetDB server v5.22.0, based on kernel v1.40.0
+# Release Oct2010-hg
+# Serving database 'mTests_src_jdbc_tests', using 4 threads
+# Compiled for x86_64-pc-linux-gnu/64bit with 64bit OIDs dynamically linked
+# Found 7.750 GiB available main-memory.
+# Copyright (c) 1993-July 2008 CWI.
+# Copyright (c) August 2008-2010 MonetDB B.V., all rights reserved
+# Visit http://monetdb.cwi.nl/ for further information
+# Listening for connection requests on mapi:monetdb://volund.ins.cwi.nl:30090/
+# MonetDB/SQL module v2.40.0 loaded
+
+Ready.
+# SQL catalog created, loading sql scripts once
+
+Over..
+
+# 10:40:26 >  
+# 10:40:26 >  ./Test_PSgeneratedkeys.SQL.sh Test_PSgeneratedkeys 
+# 10:40:26 >  
+
+
+# 10:40:26 >  
+# 10:40:26 >  java Test_PSgeneratedkeys 
"jdbc:monetdb://volund:30090/mTests_src_jdbc_tests?user=monetdb&password=monetdb"
+# 10:40:26 >  
+
+0. false       false
+1. inserting a record...success :)
+2. getting generated keys...generated key index: 1
+
+# 10:40:26 >  
+# 10:40:26 >  Done.
+# 10:40:26 >  
+
diff -r cad11c6e3bb7 -r 640b5b25fda9 sql/src/server/bin_optimizer.c
--- a/sql/src/server/bin_optimizer.c    Wed Oct 13 10:03:23 2010 +0200
+++ b/sql/src/server/bin_optimizer.c    Wed Oct 13 14:31:44 2010 +0200
@@ -313,7 +313,7 @@
                        s = stmt_reverse(stmt_limit(stmt_dup(j->op1.stval),
                                stmt_dup(s->op2.stval),
                                stmt_dup(s->op3.stval),
-                               0));
+                               s->flag));
                        ns = bin_optimizer(c, s);
                        stmt_destroy(s);
                        assert(os->rewritten==NULL);
diff -r cad11c6e3bb7 -r 640b5b25fda9 sql/src/server/rel_bin.c
--- a/sql/src/server/rel_bin.c  Wed Oct 13 10:03:23 2010 +0200
+++ b/sql/src/server/rel_bin.c  Wed Oct 13 14:31:44 2010 +0200
@@ -1939,7 +1939,7 @@
                if (oe)
                        o = exp_bin(sql, oe, NULL, NULL, NULL, NULL);
 
-               if (!le) 
+               if (!l) 
                        l = stmt_atom_wrd_nil();
                if (!o)
                        o = stmt_atom_wrd(0);
diff -r cad11c6e3bb7 -r 640b5b25fda9 testing/src/Mtest.py.in
--- a/testing/src/Mtest.py.in   Wed Oct 13 10:03:23 2010 +0200
+++ b/testing/src/Mtest.py.in   Wed Oct 13 14:31:44 2010 +0200
@@ -2564,7 +2564,7 @@
_______________________________________________
Checkin-list mailing list
[email protected]
http://mail.monetdb.org/mailman/listinfo/checkin-list

Reply via email to