Changeset: 47bb3cb873ea for MonetDB
URL: http://dev.monetdb.org/hg/MonetDB?cmd=changeset;node=47bb3cb873ea
Added Files:
        sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.sql
        sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.stable.err
        sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.stable.out
        sql/test/BugTracker-2017/Tests/drop_not_null_on_pkey.Bug-6189.sql
        sql/test/BugTracker-2017/Tests/drop_not_null_on_pkey.Bug-6189.stable.err
        sql/test/BugTracker-2017/Tests/drop_not_null_on_pkey.Bug-6189.stable.out
        sql/test/BugTracker-2017/Tests/incorrect_error.Bug-6141.sql
        sql/test/BugTracker-2017/Tests/incorrect_error.Bug-6141.stable.err
        sql/test/BugTracker-2017/Tests/incorrect_error.Bug-6141.stable.out
        sql/test/BugTracker-2017/Tests/splitpart.Bug-6194.sql
        sql/test/BugTracker-2017/Tests/splitpart.Bug-6194.stable.err
        sql/test/BugTracker-2017/Tests/splitpart.Bug-6194.stable.out
        sql/test/BugTracker-2017/Tests/union_func_crash.Bug-6196.sql
        sql/test/BugTracker-2017/Tests/union_func_crash.Bug-6196.stable.err
        sql/test/BugTracker-2017/Tests/union_func_crash.Bug-6196.stable.out
Modified Files:
        monetdb5/modules/atoms/str.c
        monetdb5/modules/kernel/mmath.mal
        monetdb5/optimizer/opt_support.c
        sql/backends/monet5/sql.c
        sql/backends/monet5/sql_cat.c
        sql/server/rel_optimizer.c
        sql/server/rel_select.c
        sql/server/sql_mvc.h
        sql/test/BugTracker-2014/Tests/too_general_errmsg.Bug-3605.stable.err
        sql/test/BugTracker-2017/Tests/All
Branch: default
Log Message:

Merge with Dec2016 branch.


diffs (truncated from 741 to 300 lines):

diff --git a/monetdb5/modules/atoms/str.c b/monetdb5/modules/atoms/str.c
--- a/monetdb5/modules/atoms/str.c
+++ b/monetdb5/modules/atoms/str.c
@@ -1863,11 +1863,11 @@ STRsplitpart(str *res, str *haystack, st
        }
    
        if (p == 0) {
-               len = UTF8_strlen(s);
+               len = strlen(s);
        } else if ((p = strstr(s, s2)) != 0) {
                len = (int) (p - s);
        } else {
-               len = UTF8_strlen(s);
+               len = strlen(s);
        }
 
        if (len == int_nil || len == 0) {
diff --git a/monetdb5/modules/kernel/mmath.mal 
b/monetdb5/modules/kernel/mmath.mal
--- a/monetdb5/modules/kernel/mmath.mal
+++ b/monetdb5/modules/kernel/mmath.mal
@@ -194,7 +194,7 @@ unsafe command rand () :int
 address MATHrandint
 comment "return a random number";
 
-command rand (v:int) :int 
+unsafe command rand (v:int) :int 
 address MATHrandintarg
 comment "return a random number";
 
diff --git a/monetdb5/optimizer/opt_support.c b/monetdb5/optimizer/opt_support.c
--- a/monetdb5/optimizer/opt_support.c
+++ b/monetdb5/optimizer/opt_support.c
@@ -277,7 +277,7 @@ isUnsafeFunction(InstrPtr q)
 }
 
 /*
- * Instructions are unsafe is one of the arguments is also mentioned
+ * Instructions are unsafe if one of the arguments is also mentioned
  * in the result list. Alternatively, the 'unsafe' property is set
  * for the function call itself.
  */
diff --git a/sql/backends/monet5/sql_cat.c b/sql/backends/monet5/sql_cat.c
--- a/sql/backends/monet5/sql_cat.c
+++ b/sql/backends/monet5/sql_cat.c
@@ -591,6 +591,15 @@ alter_table(Client cntxt, mvc *sql, char
                sql_column *nc = mvc_bind_column(sql, nt, c->base.name);
 
                if (c->null != nc->null && isTable(nt)) {
+                       if (c->null && nt->pkey) { /* check for primary keys 
based on this column */
+                               node *m;
+                               for(m = nt->pkey->k.columns->h; m; m = m->next) 
{
+                                       sql_kc *kc = m->data;
+
+                                       if (kc->c->base.id == c->base.id)
+                                               return sql_message("40000!NOT 
NULL CONSTRAINT: cannot change NOT NULL CONSTRAINT for column '%s' as its part 
of the PRIMARY KEY\n", c->base.name);
+                               }
+                       }
                        mvc_null(sql, nc, c->null);
                        /* for non empty check for nulls */
                        if (c->null == 0) {
diff --git a/sql/server/rel_optimizer.c b/sql/server/rel_optimizer.c
--- a/sql/server/rel_optimizer.c
+++ b/sql/server/rel_optimizer.c
@@ -3961,7 +3961,7 @@ rel_push_select_down(int *changes, mvc *
                pl = r->l;
                /* introduce selects under the project (if needed) */
                set_processed(pl);
-               if (!is_select(pl->op))
+               if (!is_select(pl->op) || rel_is_ref(pl))
                        r->l = pl = rel_select(sql->sa, pl, NULL);
 
                /* for each exp check if we can rename it */
@@ -4586,7 +4586,7 @@ rel_push_select_down_union(int *changes,
                if (u->op == op_project)
                        u = u->l;
 
-               if (!u || !is_union(u->op) || !u->exps || rel_is_ref(u))
+               if (!u || !is_union(u->op) || need_distinct(u) || !u->exps || 
rel_is_ref(u))
                        return rel;
 
                ul = u->l;
diff --git a/sql/server/rel_select.c b/sql/server/rel_select.c
--- a/sql/server/rel_select.c
+++ b/sql/server/rel_select.c
@@ -25,7 +25,8 @@
 #include "mal.h"               /* for have_hge */
 #endif
 
-#define check_card(card,f) ((card == card_none && !f->res) || (card != 
card_none && (f->res || f->func->type == F_FILT)) || card == card_loader)
+#define VALUE_FUNC(f) (f->func->type == F_FUNC || f->func->type == F_FILT)
+#define check_card(card,f) ((card == card_none && !f->res) || 
(CARD_VALUE(card) && f->res && VALUE_FUNC(f)) || card == card_loader || (card 
== card_relation && f->func->type == F_UNION))
 
 static void
 rel_setsubquery(sql_rel*r)
@@ -995,10 +996,15 @@ rel_column_ref(mvc *sql, sql_rel **rel, 
                        return rel_var_ref(sql, name, 0);
                }
                if (!exp && !var) {
-                       if (rel && *rel && (*rel)->card == CARD_AGGR && f == 
sql_sel)
-                               return sql_error(sql, 02, "SELECT: cannot use 
non GROUP BY column '%s' in query results without an aggregate function", name);
-                       else
-                               return sql_error(sql, 02, "SELECT: identifier 
'%s' unknown", name);
+                       if (rel && *rel && (*rel)->card == CARD_AGGR && f == 
sql_sel) {
+                               sql_rel *gb = *rel;
+
+                               while(gb->l && !is_groupby(gb->op))
+                                       gb = gb->l;
+                               if (gb && gb->l && rel_bind_column(sql, gb->l, 
name, f)) 
+                                       return sql_error(sql, 02, "SELECT: 
cannot use non GROUP BY column '%s' in query results without an aggregate 
function", name);
+                       }
+                       return sql_error(sql, 02, "SELECT: identifier '%s' 
unknown", name);
                }
                
        } else if (dlist_length(l) == 2) {
@@ -1026,10 +1032,15 @@ rel_column_ref(mvc *sql, sql_rel **rel, 
                        }
                }
                if (!exp) {
-                       if (rel && *rel && (*rel)->card == CARD_AGGR && f == 
sql_sel)
-                               return sql_error(sql, 02, "SELECT: cannot use 
non GROUP BY column '%s.%s' in query results without an aggregate function", 
tname, cname);
-                       else
-                               return sql_error(sql, 02, "42S22!SELECT: no 
such column '%s.%s'", tname, cname);
+                       if (rel && *rel && (*rel)->card == CARD_AGGR && f == 
sql_sel) {
+                               sql_rel *gb = *rel;
+
+                               while(gb->l && !is_groupby(gb->op))
+                                       gb = gb->l;
+                               if (gb && gb->l && rel_bind_column2(sql, gb->l, 
tname, cname, f))
+                                       return sql_error(sql, 02, "SELECT: 
cannot use non GROUP BY column '%s.%s' in query results without an aggregate 
function", tname, cname);
+                       }
+                       return sql_error(sql, 02, "42S22!SELECT: no such column 
'%s.%s'", tname, cname);
                }
        } else if (dlist_length(l) >= 3) {
                return sql_error(sql, 02, "TODO: column names of level >= 3");
diff --git a/sql/server/sql_mvc.h b/sql/server/sql_mvc.h
--- a/sql/server/sql_mvc.h
+++ b/sql/server/sql_mvc.h
@@ -30,6 +30,7 @@
 #define type_value     0
 #define type_predicate 1
 
+/* todo cleanup card_row and card_set, both seem to be not used */
 /* cardinality expected by enclosing operator */
 #define card_none      -1      /* psm call doesn't return anything */
 #define card_value     0
@@ -39,6 +40,7 @@
 #define card_relation  4
 #define card_loader    5
 
+#define CARD_VALUE(card) (card == card_value || card == card_row || card == 
card_column || card == card_set)
 
 /* allowed to reduce (in the where and having parts we can reduce) */
 
diff --git 
a/sql/test/BugTracker-2014/Tests/too_general_errmsg.Bug-3605.stable.err 
b/sql/test/BugTracker-2014/Tests/too_general_errmsg.Bug-3605.stable.err
--- a/sql/test/BugTracker-2014/Tests/too_general_errmsg.Bug-3605.stable.err
+++ b/sql/test/BugTracker-2014/Tests/too_general_errmsg.Bug-3605.stable.err
@@ -32,7 +32,7 @@ stderr of test 'too_general_errmsg.Bug-3
 
 MAPI  = (monetdb) /var/tmp/mtest-27483/.s.monetdb.35395
 QUERY = select operatingday, coalesce(gepubliceerd, 0) as gepubliceerd, 
coalesce(gereden, 0) as gereden, coalesce(geannuleerd, 0) as geannuleerd, 
coalesce(onbekend, 0) as onbekend, coalesce(extra, 0) as extra, 
coalesce(tochgezien, 0) as tochgezien from (select operatingday, 
count(trip_hash) as gepubliceerd from tt where pointorder = 1 group by 
operatingday) as a full outer join (select z.operatingday, count(*) as 
geannuleerd from (select trip_hash, operatingday from kv17_canceled except 
select trip_hash, operatingday from kv6 where kv6.messagetype = 'ARRIVAL') as u 
group by u.operatingday) as e using (operatingday) full outer join (select 
o.operatingday, count(trip_hash) as onbekend from (select distinct trip_hash, 
operatingday from tt) as o join (select distinct trip_hash from tt where 
(epoch(cast(tt.operatingday as timestamp with time zone)) + 
cast(split_part(tt.targetarrivaltime, ':', 1) as int) * 3600 + 
(cast(split_part(tt.targetarrivaltime, ':', 2) as int) + 10) * 60) < epoch(n
 ow()) except (select trip_hash from kv6 where messagetype = 'ARRIVAL' union 
all select trip_hash from kv17_canceled)) as p using (trip_hash) group by 
operatingday) as f using (operatingday) order by operatingday;
-ERROR = !SELECT: cannot use non GROUP BY column 'z.operatingday' in query 
results without an aggregate function
+ERROR = !SELECT: no such column 'z.operatingday'
 
 
 
diff --git a/sql/test/BugTracker-2017/Tests/All 
b/sql/test/BugTracker-2017/Tests/All
--- a/sql/test/BugTracker-2017/Tests/All
+++ b/sql/test/BugTracker-2017/Tests/All
@@ -2,7 +2,12 @@ shutdown.Bug-6182
 avggroupbysq.Bug-6178
 semijoinunion.Bug-6150
 HAVE_LIBZ?heapextend.Bug-6134
+incorrect_error.Bug-6141
 empty-interval.Bug-6184
+drop_not_null_on_pkey.Bug-6189
 too-large-decimals.Bug-6192
 round-or-truncate.Bug-6193
+splitpart.Bug-6194
 HAVE_HGE?cast-with-many-decimals.Bug-6195
+union_func_crash.Bug-6196
+complicated_logic.Bug-105
diff --git a/sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.sql 
b/sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.sql
new file mode 100644
--- /dev/null
+++ b/sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.sql
@@ -0,0 +1,5 @@
+CREATE TABLE test (id INT, a INT, b INT);
+INSERT INTO test VALUES (0, 1, 2);
+SELECT COUNT(*) FROM test WHERE (b = 1 OR b = 2) AND (a NOT IN (3, 4) OR b <> 
1) AND a = 1;
+SELECT * FROM test WHERE (b = 1 OR b = 2) AND (a NOT IN (3, 4) OR b <> 1) AND 
a = 1;
+drop table test;
diff --git 
a/sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.stable.err 
b/sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.stable.err
new file mode 100644
--- /dev/null
+++ b/sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.stable.err
@@ -0,0 +1,34 @@
+stderr of test 'complicated_logic.Bug-105` in directory 
'sql/test/BugTracker-2017` itself:
+
+
+# 17:52:48 >  
+# 17:52:48 >  "mserver5" "--debug=10" "--set" "gdk_nr_threads=0" "--set" 
"mapi_open=true" "--set" "mapi_port=38831" "--set" 
"mapi_usock=/var/tmp/mtest-13806/.s.monetdb.38831" "--set" "monet_prompt=" 
"--forcemito" 
"--dbpath=/export/scratch1/home/niels/scratch/monetdb/Linux-x86_64/var/MonetDB/mTests_sql_test_BugTracker-2017"
+# 17:52:48 >  
+
+# builtin opt  gdk_dbpath = 
/export/scratch1/home/niels/scratch/monetdb/Linux-x86_64/var/monetdb5/dbfarm/demo
+# builtin opt  gdk_debug = 0
+# builtin opt  gdk_vmtrim = no
+# builtin opt  monet_prompt = >
+# builtin opt  monet_daemon = no
+# builtin opt  mapi_port = 50000
+# builtin opt  mapi_open = false
+# builtin opt  mapi_autosense = false
+# builtin opt  sql_optimizer = default_pipe
+# builtin opt  sql_debug = 0
+# cmdline opt  gdk_nr_threads = 0
+# cmdline opt  mapi_open = true
+# cmdline opt  mapi_port = 38831
+# cmdline opt  mapi_usock = /var/tmp/mtest-13806/.s.monetdb.38831
+# cmdline opt  monet_prompt = 
+# cmdline opt  gdk_dbpath = 
/export/scratch1/home/niels/scratch/monetdb/Linux-x86_64/var/MonetDB/mTests_sql_test_BugTracker-2017
+# cmdline opt  gdk_debug = 536870922
+
+# 17:52:50 >  
+# 17:52:50 >  "mclient" "-lsql" "-ftest" "-Eutf-8" "-i" "-e" 
"--host=/var/tmp/mtest-13806" "--port=38831"
+# 17:52:50 >  
+
+
+# 17:52:56 >  
+# 17:52:56 >  "Done."
+# 17:52:56 >  
+
diff --git 
a/sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.stable.out 
b/sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.stable.out
new file mode 100644
--- /dev/null
+++ b/sql/test/BugTracker-2017/Tests/complicated_logic.Bug-105.stable.out
@@ -0,0 +1,47 @@
+stdout of test 'complicated_logic.Bug-105` in directory 
'sql/test/BugTracker-2017` itself:
+
+
+# 17:52:48 >  
+# 17:52:48 >  "mserver5" "--debug=10" "--set" "gdk_nr_threads=0" "--set" 
"mapi_open=true" "--set" "mapi_port=38831" "--set" 
"mapi_usock=/var/tmp/mtest-13806/.s.monetdb.38831" "--set" "monet_prompt=" 
"--forcemito" 
"--dbpath=/export/scratch1/home/niels/scratch/monetdb/Linux-x86_64/var/MonetDB/mTests_sql_test_BugTracker-2017"
+# 17:52:48 >  
+
+# MonetDB 5 server v11.25.6
+# This is an unreleased version
+# Serving database 'mTests_sql_test_BugTracker-2017', using 8 threads
+# Compiled for x86_64-unknown-linux-gnu/64bit with 128bit integers
+# Found 15.584 GiB available main-memory.
+# Copyright (c) 1993-July 2008 CWI.
+# Copyright (c) August 2008-2017 MonetDB B.V., all rights reserved
+# Visit http://www.monetdb.org/ for further information
+# Listening for connection requests on 
mapi:monetdb://rocks073.scilens.private:38831/
+# Listening for UNIX domain connection requests on 
mapi:monetdb:///var/tmp/mtest-13806/.s.monetdb.38831
+# MonetDB/GIS module loaded
+# MonetDB/SQL module loaded
+
+Ready.
+
+# 17:52:50 >  
+# 17:52:50 >  "mclient" "-lsql" "-ftest" "-Eutf-8" "-i" "-e" 
"--host=/var/tmp/mtest-13806" "--port=38831"
+# 17:52:50 >  
+
+#CREATE TABLE test (id INT, a INT, b INT);
+#INSERT INTO test VALUES (0, 1, 2);
+[ 1    ]
+#SELECT COUNT(*) FROM test WHERE (b = 1 OR b = 2) AND (a NOT IN (3, 4) OR b <> 
1) AND a = 1;
+% sys.L13 # table_name
+% L12 # name
+% bigint # type
+% 1 # length
+[ 1    ]
+#SELECT * FROM test WHERE (b = 1 OR b = 2) AND (a NOT IN (3, 4) OR b <> 1) AND 
a = 1;
+% sys.test,    sys.test,       sys.test # table_name
+% id,  a,      b # name
+% int, int,    int # type
+% 1,   1,      1 # length
+[ 0,   1,      2       ]
+#drop table test;
+
+# 17:52:56 >  
+# 17:52:56 >  "Done."
+# 17:52:56 >  
+
diff --git a/sql/test/BugTracker-2017/Tests/drop_not_null_on_pkey.Bug-6189.sql 
b/sql/test/BugTracker-2017/Tests/drop_not_null_on_pkey.Bug-6189.sql
new file mode 100644
--- /dev/null
+++ b/sql/test/BugTracker-2017/Tests/drop_not_null_on_pkey.Bug-6189.sql
@@ -0,0 +1,39 @@
+CREATE TABLE "PKeyNotNull" (
+       "PK_COL1" varchar(4) NOT NULL,
+       "PK_COL2" varchar(4) NOT NULL,
+       "DataCol" int DEFAULT NULL,
+       PRIMARY KEY ("PK_COL1","PK_COL2") );
+
+\d "PKeyNotNull"
+
+INSERT INTO "PKeyNotNull" values ('C12', NULL, 1);
+-- Error: INSERT INTO: NOT NULL constraint violated for column 
PKeyNotNull.PK_COL2
+
+ALTER TABLE "PKeyNotNull" ALTER "PK_COL2" SET NULL;
+-- this is allowed but should NOT be allowed
_______________________________________________
checkin-list mailing list
[email protected]
https://www.monetdb.org/mailman/listinfo/checkin-list

Reply via email to