Changeset: d9522af3d796 for MonetDB URL: http://dev.monetdb.org/hg/MonetDB?cmd=changeset;node=d9522af3d796 Added Files: sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.sql sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.stable.err sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.stable.out Modified Files: sql/backends/monet5/rel_bin.c sql/common/sql_types.c sql/test/BugTracker-2016/Tests/All Branch: Jul2015 Log Message:
more strict integer/decimal type handling diffs (208 lines): diff --git a/sql/backends/monet5/rel_bin.c b/sql/backends/monet5/rel_bin.c --- a/sql/backends/monet5/rel_bin.c +++ b/sql/backends/monet5/rel_bin.c @@ -3198,7 +3198,7 @@ rel2bin_insert( mvc *sql, sql_rel *rel, if (i->key && constraint) { stmt *ckeys = sql_insert_key(sql, newl, i->key, is, pin); - list_prepend(l, ckeys); + list_append(l, ckeys); } if (!insert) insert = is; @@ -3212,9 +3212,9 @@ rel2bin_insert( mvc *sql, sql_rel *rel, if (!insert) return NULL; - l = list_append(l, stmt_list(sql->sa, newl)); if (constraint) sql_insert_check_null(sql, t, newl, l); + l = list_append(l, stmt_list(sql->sa, newl)); if (!sql_insert_triggers(sql, t, l)) return sql_error(sql, 02, "INSERT INTO: triggers failed for table '%s'", t->base.name); if (insert->op1->nrcols == 0) { diff --git a/sql/common/sql_types.c b/sql/common/sql_types.c --- a/sql/common/sql_types.c +++ b/sql/common/sql_types.c @@ -44,7 +44,7 @@ int digits2bits(int digits) else if (digits < 5) return 16; else if (digits <= 8) - return 28; + return 27; else if (digits < 10) return 32; else if (digits < 17) @@ -74,9 +74,9 @@ int bits2digits(int bits) return 6; else if (bits < 24) return 7; - else if (bits < 27) + else if (bits <= 27) return 8; - else if (bits < 30) + else if (bits <= 30) return 9; else if (bits <= 32) return 10; diff --git a/sql/test/BugTracker-2016/Tests/All b/sql/test/BugTracker-2016/Tests/All --- a/sql/test/BugTracker-2016/Tests/All +++ b/sql/test/BugTracker-2016/Tests/All @@ -12,3 +12,4 @@ rank_rewrite.Bug-3890 HAVE_LIBBZ2?min-max-uuid-column-wrong-results.Bug-3953 update_crash.Bug-3954 merge_project.Bug-3955 +decimal_vs_integer.Bug-3941 diff --git a/sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.sql b/sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.sql new file mode 100644 --- /dev/null +++ b/sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.sql @@ -0,0 +1,7 @@ + +start transaction; +create table tmp(i decimal(8)); +explain select count(*) from tmp where i = 20160222; +explain select count(*) from tmp where i = '20160222'; +explain select count(*) from tmp where i = 201602221; + diff --git a/sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.stable.err b/sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.stable.err new file mode 100644 --- /dev/null +++ b/sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.stable.err @@ -0,0 +1,37 @@ +stderr of test 'decimal_vs_integer.Bug-3941` in directory 'sql/test/BugTracker-2016` itself: + + +# 15:01:29 > +# 15:01:29 > "mserver5" "--debug=10" "--set" "gdk_nr_threads=0" "--set" "mapi_open=true" "--set" "mapi_port=37542" "--set" "mapi_usock=/var/tmp/mtest-23330/.s.monetdb.37542" "--set" "monet_prompt=" "--forcemito" "--set" "mal_listing=2" "--dbpath=/home/niels/scratch/rc-monetdb/Linux-x86_64/var/MonetDB/mTests_sql_test_BugTracker-2016" "--set" "mal_listing=0" "--set" "embedded_r=yes" +# 15:01:29 > + +# builtin opt gdk_dbpath = /home/niels/scratch/rc-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 = 37542 +# cmdline opt mapi_usock = /var/tmp/mtest-23330/.s.monetdb.37542 +# cmdline opt monet_prompt = +# cmdline opt mal_listing = 2 +# cmdline opt gdk_dbpath = /home/niels/scratch/rc-monetdb/Linux-x86_64/var/MonetDB/mTests_sql_test_BugTracker-2016 +# cmdline opt mal_listing = 0 +# cmdline opt embedded_r = yes +# cmdline opt gdk_debug = 536870922 + +# 15:01:30 > +# 15:01:30 > "mclient" "-lsql" "-ftest" "-Eutf-8" "-i" "-e" "--host=/var/tmp/mtest-23330" "--port=37542" +# 15:01:30 > + + +# 15:01:30 > +# 15:01:30 > "Done." +# 15:01:30 > + diff --git a/sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.stable.out b/sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.stable.out new file mode 100644 --- /dev/null +++ b/sql/test/BugTracker-2016/Tests/decimal_vs_integer.Bug-3941.stable.out @@ -0,0 +1,94 @@ +stdout of test 'decimal_vs_integer.Bug-3941` in directory 'sql/test/BugTracker-2016` itself: + + +# 15:01:29 > +# 15:01:29 > "mserver5" "--debug=10" "--set" "gdk_nr_threads=0" "--set" "mapi_open=true" "--set" "mapi_port=37542" "--set" "mapi_usock=/var/tmp/mtest-23330/.s.monetdb.37542" "--set" "monet_prompt=" "--forcemito" "--set" "mal_listing=2" "--dbpath=/home/niels/scratch/rc-monetdb/Linux-x86_64/var/MonetDB/mTests_sql_test_BugTracker-2016" "--set" "mal_listing=0" "--set" "embedded_r=yes" +# 15:01:29 > + +# MonetDB 5 server v11.21.12 +# This is an unreleased version +# Serving database 'mTests_sql_test_BugTracker-2016', using 4 threads +# Compiled for x86_64-unknown-linux-gnu/64bit with 64bit OIDs and 128bit integers dynamically linked +# Found 7.332 GiB available main-memory. +# Copyright (c) 1993-July 2008 CWI. +# Copyright (c) August 2008-2015 MonetDB B.V., all rights reserved +# Visit http://www.monetdb.org/ for further information +# Listening for connection requests on mapi:monetdb://localhost.nes.nl:37542/ +# Listening for UNIX domain connection requests on mapi:monetdb:///var/tmp/mtest-23330/.s.monetdb.37542 +# MonetDB/GIS module loaded +# Start processing logs sql/sql_logs version 52200 +# Start reading the write-ahead log 'sql_logs/sql/log.11' +# Finished reading the write-ahead log 'sql_logs/sql/log.11' +# Finished processing logs sql/sql_logs +# MonetDB/SQL module loaded +# MonetDB/R module loaded + +Ready. + +# 15:01:30 > +# 15:01:30 > "mclient" "-lsql" "-ftest" "-Eutf-8" "-i" "-e" "--host=/var/tmp/mtest-23330" "--port=37542" +# 15:01:30 > + +#start transaction; +#create table tmp(i decimal(8)); +#explain select count(*) from tmp where i = 20160222; +% .explain # table_name +% mal # name +% clob # type +% 107 # length +function user.s2_1(A0:int):void; + X_21:void := querylog.define("explain select count(*) from tmp where i = 20160222;","default_pipe",11); + X_2 := sql.mvc(); + X_6:bat[:oid,:int] := sql.bind(X_2,"sys","tmp","i",0); + X_9 := X_6; + X_3:bat[:oid,:oid] := sql.tid(X_2,"sys","tmp"); + X_10 := algebra.subselect(X_9,X_3,A0,A0,true,false,false); + X_13 := algebra.leftfetchjoin(X_10,X_9); + X_14 := aggr.count(X_13); + sql.resultSet("sys.L1","L1","wrd",64,0,7,X_14); +end user.s2_1; +# optimizer.mitosis() +# optimizer.dataflow() +#explain select count(*) from tmp where i = '20160222'; +% .explain # table_name +% mal # name +% clob # type +% 113 # length +function user.s3_1(A0:str):void; + X_23:void := querylog.define("explain select count(*) from tmp where i = \\'20160222\\';","default_pipe",12); + X_2 := sql.mvc(); + X_6:bat[:oid,:int] := sql.bind(X_2,"sys","tmp","i",0); + X_9 := X_6; + X_3:bat[:oid,:oid] := sql.tid(X_2,"sys","tmp"); + X_10 := calc.int(A0,8,0); + X_12 := algebra.subselect(X_9,X_3,X_10,X_10,true,false,false); + X_15 := algebra.leftfetchjoin(X_12,X_9); + X_16 := aggr.count(X_15); + sql.resultSet("sys.L1","L1","wrd",64,0,7,X_16); +end user.s3_1; +# optimizer.mitosis() +# optimizer.dataflow() +#explain select count(*) from tmp where i = 201602221; +% .explain # table_name +% mal # name +% clob # type +% 108 # length +function user.s4_1(A0:lng):void; + X_23:void := querylog.define("explain select count(*) from tmp where i = 201602221;","default_pipe",12); + X_2 := sql.mvc(); + X_6:bat[:oid,:int] := sql.bind(X_2,"sys","tmp","i",0); + X_9 := X_6; + X_10:bat[:oid,:lng] := batcalc.lng(0,X_9,10,0); + X_3:bat[:oid,:oid] := sql.tid(X_2,"sys","tmp"); + X_12 := algebra.subselect(X_10,X_3,A0,A0,true,false,false); + X_15 := algebra.leftfetchjoin(X_12,X_9); + X_16 := aggr.count(X_15); + sql.resultSet("sys.L1","L1","wrd",64,0,7,X_16); +end user.s4_1; +# optimizer.mitosis() +# optimizer.dataflow() + +# 15:01:30 > +# 15:01:30 > "Done." +# 15:01:30 > + _______________________________________________ checkin-list mailing list checkin-list@monetdb.org https://www.monetdb.org/mailman/listinfo/checkin-list