Changeset: c8d68fe84672 for MonetDB
URL: https://dev.monetdb.org/hg/MonetDB/rev/c8d68fe84672
Modified Files:
        tools/merovingian/daemon/merovingian.c
Branch: default
Log Message:

Merge with Sep2022 branch.


diffs (truncated from 413 to 300 lines):

diff --git a/clients/odbc/ChangeLog.Sep2022 b/clients/odbc/ChangeLog.Sep2022
--- a/clients/odbc/ChangeLog.Sep2022
+++ b/clients/odbc/ChangeLog.Sep2022
@@ -1,3 +1,7 @@
 # ChangeLog file for odbc
 # This file is updated with Maddlog
 
+* Thu Oct 13 2022 Martin van Dinther <martin.van.dint...@monetdbsolutions.com>
+- Fixed issue with generated raw strings prefix when ODBC driver is used
+  against a server older than Jun2020 (11.37).
+
diff --git a/clients/odbc/driver/ODBCUtil.c b/clients/odbc/driver/ODBCUtil.c
--- a/clients/odbc/driver/ODBCUtil.c
+++ b/clients/odbc/driver/ODBCUtil.c
@@ -1074,6 +1074,7 @@ ODBCTranslateSQL(ODBCDbc *dbc, const SQL
                         * ESCAPE '\\'
                         */
                        char esc;
+                       const char *s;
                        p += 7;
                        while (*p == ' ')
                                p++;
@@ -1106,7 +1107,13 @@ ODBCTranslateSQL(ODBCDbc *dbc, const SQL
                                length = (size_t) snprintf(q, length, "%.*s 
ESCAPE '''' %s", n, nquery, p);
                                break;
                        case '\\':
-                               length = (size_t) snprintf(q, length, "%.*s 
ESCAPE r'\\' %s", n, nquery, p);
+                               /* raw strings prefix syntax is only supported 
by servers since Jun2020 (11.37) */
+                               if (dbc->major == 11 && dbc->minor >= 37) {
+                                       s = "%.*s ESCAPE r'\\'";
+                               } else {
+                                       s = "%.*s ESCAPE '\\\\'";
+                               }
+                               length = (size_t) snprintf(q, length, s, n, 
nquery, p);
                                break;
                        default:
                                length = (size_t) snprintf(q, length, "%.*s 
ESCAPE '%c' %s", n, nquery, esc, p);
@@ -1256,7 +1263,8 @@ ODBCTranslateSQL(ODBCDbc *dbc, const SQL
                                                for (r = func->repl; *r; r++) {
                                                        if (*r == '\1' || *r == 
'\2' || *r == '\3' || *r == '\4') {
                                                                assert(*r <= 
func->nargs);
-                                                               if (args[*r - 
1].argstart[0] == '\'')
+                                                               /* raw strings 
prefix syntax is only supported by servers since Jun2020 (11.37) */
+                                                               if (args[*r - 
1].argstart[0] == '\'' && dbc->major == 11 && dbc->minor >= 37)
                                                                        q[pr++] 
= 'r';
                                                                strncpy(q + pr, 
args[*r - 1].argstart, args[*r - 1].arglen);
                                                                pr += (int) 
args[*r - 1].arglen;
@@ -1350,7 +1358,7 @@ ODBCParseOA(const char *tab, const char 
 }
 
 char *
-ODBCParsePV(const char *tab, const char *col, const char *arg, size_t len)
+ODBCParsePV(const char *tab, const char *col, const char *arg, size_t len, 
const ODBCDbc *dbc)
 {
        size_t i;
        char *res;
@@ -1371,7 +1379,13 @@ ODBCParsePV(const char *tab, const char 
                        res[i++] = *s;
                res[i++] = *s;
        }
-       for (s = "' escape r'\\'"; *s; s++)
+       /* raw strings prefix syntax is only supported by servers since Jun2020 
(11.37) */
+       if (dbc->major == 11 && dbc->minor >= 37) {
+               s = "' escape r'\\'";
+       } else {
+               s = "' escape '\\\\'";
+       }
+       for (; *s; s++)
                res[i++] = *s;
        res[i] = 0;
        return res;
diff --git a/clients/odbc/driver/ODBCUtil.h b/clients/odbc/driver/ODBCUtil.h
--- a/clients/odbc/driver/ODBCUtil.h
+++ b/clients/odbc/driver/ODBCUtil.h
@@ -31,6 +31,7 @@
 #define _H_ODBCUTIL
 
 #include "ODBCGlobal.h"
+#include "ODBCDbc.h"
 
 
 /*
@@ -145,7 +146,7 @@ extern const char *ODBCutf82wchar(const 
 #endif
 
 char *ODBCParseOA(const char *tab, const char *col, const char *arg, size_t 
len);
-char *ODBCParsePV(const char *tab, const char *col, const char *arg, size_t 
len);
+char *ODBCParsePV(const char *tab, const char *col, const char *arg, size_t 
len, const ODBCDbc *dbc);
 char *ODBCParseID(const char *tab, const char *col, const char *arg, size_t 
len);
 
 /* SQL_DESC_CONCISE_TYPE, SQL_DESC_DATETIME_INTERVAL_CODE, and
diff --git a/clients/odbc/driver/SQLColumnPrivileges.c 
b/clients/odbc/driver/SQLColumnPrivileges.c
--- a/clients/odbc/driver/SQLColumnPrivileges.c
+++ b/clients/odbc/driver/SQLColumnPrivileges.c
@@ -81,7 +81,8 @@ MNDBColumnPrivileges(ODBCStmt *stmt,
                if (NameLength4 > 0) {
                        col = ODBCParsePV("tc", "cname",
                                          (const char *) ColumnName,
-                                         (size_t) NameLength4);
+                                         (size_t) NameLength4,
+                                         stmt->Dbc);
                        if (col == NULL)
                                goto nomem;
                }
diff --git a/clients/odbc/driver/SQLColumns.c b/clients/odbc/driver/SQLColumns.c
--- a/clients/odbc/driver/SQLColumns.c
+++ b/clients/odbc/driver/SQLColumns.c
@@ -79,21 +79,24 @@ MNDBColumns(ODBCStmt *stmt,
                if (NameLength2 > 0) {
                        sch = ODBCParsePV("s", "name",
                                          (const char *) SchemaName,
-                                         (size_t) NameLength2);
+                                         (size_t) NameLength2,
+                                         stmt->Dbc);
                        if (sch == NULL)
                                goto nomem;
                }
                if (NameLength3 > 0) {
                        tab = ODBCParsePV("t", "name",
                                          (const char *) TableName,
-                                         (size_t) NameLength3);
+                                         (size_t) NameLength3,
+                                         stmt->Dbc);
                        if (tab == NULL)
                                goto nomem;
                }
                if (NameLength4 > 0) {
                        col = ODBCParsePV("c", "name",
                                          (const char *) ColumnName,
-                                         (size_t) NameLength4);
+                                         (size_t) NameLength4,
+                                         stmt->Dbc);
                        if (col == NULL)
                                goto nomem;
                }
diff --git a/clients/odbc/driver/SQLProcedureColumns.c 
b/clients/odbc/driver/SQLProcedureColumns.c
--- a/clients/odbc/driver/SQLProcedureColumns.c
+++ b/clients/odbc/driver/SQLProcedureColumns.c
@@ -71,21 +71,24 @@ MNDBProcedureColumns(ODBCStmt *stmt,
                if (NameLength2 > 0) {
                        sch = ODBCParsePV("s", "name",
                                          (const char *) SchemaName,
-                                         (size_t) NameLength2);
+                                         (size_t) NameLength2,
+                                         stmt->Dbc);
                        if (sch == NULL)
                                goto nomem;
                }
                if (NameLength3 > 0) {
                        prc = ODBCParsePV("p", "name",
                                          (const char *) ProcName,
-                                         (size_t) NameLength3);
+                                         (size_t) NameLength3,
+                                         stmt->Dbc);
                        if (prc == NULL)
                                goto nomem;
                }
                if (NameLength4 > 0) {
                        col = ODBCParsePV("a", "name",
                                          (const char *) ColumnName,
-                                         (size_t) NameLength4);
+                                         (size_t) NameLength4,
+                                         stmt->Dbc);
                        if (col == NULL)
                                goto nomem;
                }
diff --git a/clients/odbc/driver/SQLProcedures.c 
b/clients/odbc/driver/SQLProcedures.c
--- a/clients/odbc/driver/SQLProcedures.c
+++ b/clients/odbc/driver/SQLProcedures.c
@@ -79,14 +79,16 @@ MNDBProcedures(ODBCStmt *stmt,
                if (NameLength2 > 0) {
                        sch = ODBCParsePV("s", "name",
                                          (const char *) SchemaName,
-                                         (size_t) NameLength2);
+                                         (size_t) NameLength2,
+                                         stmt->Dbc);
                        if (sch == NULL)
                                goto nomem;
                }
                if (NameLength3 > 0) {
                        pro = ODBCParsePV("p", "name",
                                          (const char *) ProcName,
-                                         (size_t) NameLength3);
+                                         (size_t) NameLength3,
+                                         stmt->Dbc);
                        if (pro == NULL)
                                goto nomem;
                }
diff --git a/clients/odbc/driver/SQLTablePrivileges.c 
b/clients/odbc/driver/SQLTablePrivileges.c
--- a/clients/odbc/driver/SQLTablePrivileges.c
+++ b/clients/odbc/driver/SQLTablePrivileges.c
@@ -66,14 +66,16 @@ MNDBTablePrivileges(ODBCStmt *stmt,
                if (NameLength2 > 0) {
                        sch = ODBCParsePV("s", "name",
                                          (const char *) SchemaName,
-                                         (size_t) NameLength2);
+                                         (size_t) NameLength2,
+                                         stmt->Dbc);
                        if (sch == NULL)
                                goto nomem;
                }
                if (NameLength3 > 0) {
                        tab = ODBCParsePV("t", "name",
                                          (const char *) TableName,
-                                         (size_t) NameLength3);
+                                         (size_t) NameLength3,
+                                         stmt->Dbc);
                        if (tab == NULL)
                                goto nomem;
                }
diff --git a/clients/odbc/driver/SQLTables.c b/clients/odbc/driver/SQLTables.c
--- a/clients/odbc/driver/SQLTables.c
+++ b/clients/odbc/driver/SQLTables.c
@@ -125,14 +125,16 @@ MNDBTables(ODBCStmt *stmt,
                        if (NameLength2 > 0) {
                                sch = ODBCParsePV("s", "name",
                                                  (const char *) SchemaName,
-                                                 (size_t) NameLength2);
+                                                 (size_t) NameLength2,
+                                                 stmt->Dbc);
                                if (sch == NULL)
                                        goto nomem;
                        }
                        if (NameLength3 > 0) {
                                tab = ODBCParsePV("t", "name",
                                                  (const char *) TableName,
-                                                 (size_t) NameLength3);
+                                                 (size_t) NameLength3,
+                                                 stmt->Dbc);
                                if (tab == NULL)
                                        goto nomem;
                        }
diff --git a/sql/server/rel_optimize_others.c b/sql/server/rel_optimize_others.c
--- a/sql/server/rel_optimize_others.c
+++ b/sql/server/rel_optimize_others.c
@@ -1033,7 +1033,7 @@ bind_dce(visitor *v, global_props *gp)
 
 
 static int
-topn_sample_save_exps( list *exps )
+topn_sample_safe_exps( list *exps, bool nil_limit )
 {
        /* Limit only expression lists are always save */
        if (list_length(exps) == 1)
@@ -1041,7 +1041,7 @@ topn_sample_save_exps( list *exps )
        for (node *n = exps->h; n; n = n->next ) {
                sql_exp *e = n->data;
 
-               if (!e || e->type != e_atom)
+               if (!e || e->type != e_atom || (!nil_limit && exp_is_null(e)))
                        return 0;
        }
        return 1;
@@ -1081,9 +1081,9 @@ sum_limit_offset(mvc *sql, sql_rel *rel)
 static sql_rel *
 rel_push_topn_and_sample_down_(visitor *v, sql_rel *rel)
 {
-       sql_rel *rp = NULL, *r = rel->l;
+       sql_rel *rp = NULL, *r = rel->l, *rpp = NULL;
 
-       if ((is_topn(rel->op) || is_sample(rel->op)) && 
topn_sample_save_exps(rel->exps)) {
+       if ((is_topn(rel->op) || is_sample(rel->op)) && 
topn_sample_safe_exps(rel->exps, true)) {
                sql_rel *(*func) (sql_allocator *, sql_rel *, list *) = 
is_topn(rel->op) ? rel_topn : rel_sample;
 
                /* nested topN relations */
@@ -1152,6 +1152,9 @@ rel_push_topn_and_sample_down_(visitor *
                        return rel;
                }
 
+               if (!topn_sample_safe_exps(rel->exps, false))
+                       return rel;
+
                /* duplicate topn/sample direct under union or crossproduct */
                if (r && !rel_is_ref(r) && r->l && r->r && ((is_union(r->op) && 
r->exps) || (r->op == op_join && list_empty(r->exps)))) {
                        sql_rel *u = r, *x;
@@ -1185,7 +1188,7 @@ rel_push_topn_and_sample_down_(visitor *
                }
 
                /* duplicate topn/sample + [ project-order ] under union */
-               if (r)
+               if (r && !rp)
                        rp = r->l;
                if (r && r->exps && is_simple_project(r->op) && !rel_is_ref(r) 
&& !list_empty(r->r) && r->l && is_union(rp->op)) {
                        sql_rel *u = rp, *ou = u, *x, *ul = u->l, *ur = u->r;
@@ -1268,6 +1271,50 @@ rel_push_topn_and_sample_down_(visitor *
                        v->changes++;
                        return rel;
                }
+               /* a  left outer join b order by a.* limit L, can be copied 
into a */
+               /* topn ( project (orderby)( optional project ( left ())
+                * rel    r                                     rp */
+               if (r && !rp)
+                       rp = r->l;
+               if (r && rp && is_simple_project(rp->op) && !rp->r && rp->l)
+                       rpp = rp->l;
+               if (r && r->exps && is_simple_project(r->op) && !rel_is_ref(r) 
&& r->r && r->l && ((!rpp && is_left(rp->op)) ||
+                               (rpp && is_left(rpp->op)))) {
+                       sql_rel *lj = rpp?rpp:rp;
+                       sql_rel *l = lj->l;
+                       list *obes = r->r, *nobes = sa_list(v->sql->sa);
_______________________________________________
checkin-list mailing list -- checkin-list@monetdb.org
To unsubscribe send an email to checkin-list-le...@monetdb.org

Reply via email to