Line data Source code
1 : /*
2 : * SPDX-License-Identifier: MPL-2.0
3 : *
4 : * This Source Code Form is subject to the terms of the Mozilla Public
5 : * License, v. 2.0. If a copy of the MPL was not distributed with this
6 : * file, You can obtain one at http://mozilla.org/MPL/2.0/.
7 : *
8 : * Copyright 2024 MonetDB Foundation;
9 : * Copyright August 2008 - 2023 MonetDB B.V.;
10 : * Copyright 1997 - July 2008 CWI.
11 : */
12 :
13 : /*
14 : * SQL upgrade code
15 : * N. Nes, M.L. Kersten, S. Mullender
16 : */
17 : #include "monetdb_config.h"
18 : #include "mal_backend.h"
19 : #include "sql_execute.h"
20 : #include "sql_mvc.h"
21 : #include "gdk_time.h"
22 : #include <unistd.h>
23 : #include "sql_upgrades.h"
24 : #include "rel_rel.h"
25 : #include "rel_semantic.h"
26 :
27 : #include "mal_authorize.h"
28 :
29 : /* this function can be used to recreate the system tables (types,
30 : * functions, args) when internal types and/or functions have changed
31 : * (i.e. the ones in sql_types.c) */
32 : static str
33 12 : sql_fix_system_tables(Client c, mvc *sql)
34 : {
35 12 : size_t bufsize = 1000000, pos = 0;
36 12 : char *buf = GDKmalloc(bufsize), *err = NULL;
37 12 : node *n;
38 12 : sql_schema *s;
39 12 : static const char *boolnames[2] = {"false", "true"};
40 :
41 12 : if (buf == NULL)
42 0 : throw(SQL, __func__, SQLSTATE(HY013) MAL_MALLOC_FAIL);
43 12 : s = mvc_bind_schema(sql, "sys");
44 :
45 12 : pos += snprintf(buf + pos, bufsize - pos,
46 : "delete from sys.dependencies where id < 2000;\n");
47 :
48 : /* recreate internal types */
49 12 : pos += snprintf(buf + pos, bufsize - pos,
50 : "delete from sys.types where id < 2000;\n");
51 384 : for (n = types->h; n; n = n->next) {
52 372 : sql_type *t = n->data;
53 :
54 372 : if (t->base.id >= FUNC_OIDS)
55 0 : continue;
56 :
57 372 : pos += snprintf(buf + pos, bufsize - pos,
58 : "insert into sys.types values"
59 : " (%d, '%s', '%s', %u, %u, %d, %d, %d);\n",
60 : t->base.id, t->impl, t->base.name, t->digits,
61 372 : t->scale, t->radix, (int) t->eclass,
62 372 : t->s ? t->s->base.id : s->base.id);
63 : }
64 :
65 : /* recreate internal functions */
66 12 : pos += snprintf(buf + pos, bufsize - pos,
67 : "delete from sys.functions where id < 2000;\n"
68 : "delete from sys.args where func_id not in"
69 : " (select id from sys.functions);\n");
70 12 : sqlstore *store = sql->session->tr->store;
71 11316 : for (n = funcs->h; n; n = n->next) {
72 11304 : sql_func *func = n->data;
73 11304 : int number = 0;
74 11304 : sql_arg *arg;
75 11304 : node *m;
76 :
77 11304 : if (func->private || func->base.id >= FUNC_OIDS)
78 2748 : continue;
79 :
80 17112 : pos += snprintf(buf + pos, bufsize - pos,
81 : "insert into sys.functions values"
82 : " (%d, '%s', '%s', '%s',"
83 : " %d, %d, %s, %s, %s, %d, %s, %s);\n",
84 : func->base.id, func->base.name,
85 : sql_func_imp(func), sql_func_mod(func), (int) FUNC_LANG_INT,
86 8556 : (int) func->type,
87 8556 : boolnames[func->side_effect],
88 8556 : boolnames[func->varres],
89 8556 : boolnames[func->vararg],
90 8556 : func->s ? func->s->base.id : s->base.id,
91 8556 : boolnames[func->system],
92 8556 : boolnames[func->semantics]);
93 8556 : if (func->res) {
94 17064 : for (m = func->res->h; m; m = m->next, number++) {
95 8532 : arg = m->data;
96 8532 : pos += snprintf(buf + pos, bufsize - pos,
97 : "insert into sys.args"
98 : " values"
99 : " (%d, %d, 'res_%d',"
100 : " '%s', %u, %u, %d,"
101 : " %d);\n",
102 : store_next_oid(store),
103 : func->base.id,
104 : number,
105 8532 : arg->type.type->base.name,
106 : arg->type.digits,
107 : arg->type.scale,
108 8532 : arg->inout, number);
109 : }
110 : }
111 22800 : for (m = func->ops->h; m; m = m->next, number++) {
112 14244 : arg = m->data;
113 14244 : if (arg->name)
114 0 : pos += snprintf(buf + pos, bufsize - pos,
115 : "insert into sys.args"
116 : " values"
117 : " (%d, %d, '%s', '%s',"
118 : " %u, %u, %d, %d);\n",
119 : store_next_oid(store),
120 : func->base.id,
121 : arg->name,
122 0 : arg->type.type->base.name,
123 : arg->type.digits,
124 : arg->type.scale,
125 0 : arg->inout, number);
126 : else
127 14244 : pos += snprintf(buf + pos, bufsize - pos,
128 : "insert into sys.args"
129 : " values"
130 : " (%d, %d, 'arg_%d',"
131 : " '%s', %u, %u, %d,"
132 : " %d);\n",
133 : store_next_oid(store),
134 : func->base.id,
135 : number,
136 14244 : arg->type.type->base.name,
137 : arg->type.digits,
138 : arg->type.scale,
139 14244 : arg->inout, number);
140 : }
141 : }
142 :
143 12 : assert(pos < bufsize);
144 12 : printf("Running database upgrade commands to update system tables.\n\n");
145 12 : fflush(stdout);
146 12 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
147 12 : GDKfree(buf);
148 12 : return err; /* usually MAL_SUCCEED */
149 : }
150 :
151 : static str
152 96 : check_sys_tables(Client c, mvc *m, sql_schema *s)
153 : {
154 96 : struct {
155 : const char *name;
156 : const char *func;
157 : const char *type;
158 : sql_ftype ftype;
159 96 : } tests[] = {
160 : /* tests a few internal functions: the last one created, the
161 : * first one created, and one of the first ones created after
162 : * the geom module */
163 : { "quarter", "quarter", "date", F_FUNC, },
164 : { "sys_update_tables", "update_tables", NULL, F_PROC, },
165 : { "length", "nitems", "blob", F_FUNC, },
166 : { "isnull", "isnil", "void", F_FUNC, },
167 : {0},
168 : };
169 96 : char *err;
170 :
171 : /* if any of the tested function's internal ID does not match the ID
172 : * in the sys.functions table, we recreate the internal part of the
173 : * system tables */
174 432 : for (int i = 0; tests[i].name; i++) {
175 348 : bool needsystabfix = true;
176 348 : sql_subtype tp, *tpp;
177 348 : if (tests[i].type) {
178 264 : sql_find_subtype(&tp, tests[i].type, 0, 0);
179 264 : tpp = &tp;
180 : } else {
181 : tpp = NULL;
182 : }
183 348 : sql_subfunc *f = sql_bind_func(m, s->base.name, tests[i].name, tpp, NULL, tests[i].ftype, true, true);
184 348 : if (f == NULL)
185 12 : throw(SQL, __func__, "cannot find procedure sys.%s(%s)", tests[i].name, tests[i].type ? tests[i].type : "");
186 348 : sqlid id = f->func->base.id;
187 348 : char buf[256];
188 348 : snprintf(buf, sizeof(buf),
189 : "select id from sys.functions where name = '%s' and func = '%s' and schema_id = 2000;\n",
190 : tests[i].name, tests[i].func);
191 348 : res_table *output = NULL;
192 348 : err = SQLstatementIntern(c, buf, "update", true, false, &output);
193 348 : if (err)
194 0 : return err;
195 348 : BAT *b;
196 348 : b = BATdescriptor(output->cols[0].b);
197 348 : res_table_destroy(output);
198 348 : if (b == NULL)
199 0 : throw(SQL, "sql.catalog", SQLSTATE(HY013) MAL_MALLOC_FAIL);
200 348 : if (BATcount(b) > 0) {
201 348 : BATiter bi = bat_iterator(b);
202 348 : needsystabfix = * (int *) BUNtloc(bi, 0) != id;
203 348 : bat_iterator_end(&bi);
204 : }
205 348 : BBPunfix(b->batCacheid);
206 348 : if (i == 0 && !needsystabfix) {
207 84 : snprintf(buf, sizeof(buf),
208 : "select a.type from sys.functions f join sys.args a on f.id = a.func_id where f.name = 'quarter' and f.schema_id = 2000 and a.inout = 0 and a.type = 'int';\n");
209 84 : err = SQLstatementIntern(c, buf, "update", true, false, &output);
210 84 : if (err)
211 0 : return err;
212 84 : b = BATdescriptor(output->cols[0].b);
213 84 : res_table_destroy(output);
214 84 : if (b == NULL)
215 0 : throw(SQL, "sql.catalog", SQLSTATE(HY013) MAL_MALLOC_FAIL);
216 84 : needsystabfix = BATcount(b) > 0;
217 84 : BBPunfix(b->batCacheid);
218 : }
219 348 : if (needsystabfix)
220 12 : return sql_fix_system_tables(c, m);
221 : }
222 : return NULL;
223 : }
224 :
225 : #ifdef HAVE_HGE
226 : static str
227 8 : sql_update_hugeint(Client c, mvc *sql)
228 : {
229 8 : size_t bufsize = 8192, pos = 0;
230 8 : char *buf, *err;
231 :
232 8 : (void) sql;
233 8 : if ((buf = GDKmalloc(bufsize)) == NULL)
234 0 : throw(SQL, __func__, SQLSTATE(HY013) MAL_MALLOC_FAIL);
235 :
236 : /* 90_generator_hge.sql */
237 8 : pos += snprintf(buf + pos, bufsize - pos,
238 : "create function sys.generate_series(first hugeint, \"limit\" hugeint)\n"
239 : "returns table (value hugeint)\n"
240 : "external name generator.series;\n"
241 : "create function sys.generate_series(first hugeint, \"limit\" hugeint, stepsize hugeint)\n"
242 : "returns table (value hugeint)\n"
243 : "external name generator.series;\n"
244 : "grant execute on function sys.generate_series(hugeint, hugeint) to public;\n"
245 : "grant execute on function sys.generate_series(hugeint, hugeint, hugeint) to public;\n");
246 :
247 : /* 39_analytics_hge.sql */
248 8 : pos += snprintf(buf + pos, bufsize - pos,
249 : "create aggregate stddev_samp(val HUGEINT) returns DOUBLE\n"
250 : " external name \"aggr\".\"stdev\";\n"
251 : "GRANT EXECUTE ON AGGREGATE stddev_samp(HUGEINT) TO PUBLIC;\n"
252 : "create window stddev_samp(val HUGEINT) returns DOUBLE\n"
253 : " external name \"sql\".\"stdev\";\n"
254 : "GRANT EXECUTE ON WINDOW stddev_samp(HUGEINT) TO PUBLIC;\n"
255 : "create aggregate stddev_pop(val HUGEINT) returns DOUBLE\n"
256 : " external name \"aggr\".\"stdevp\";\n"
257 : "GRANT EXECUTE ON AGGREGATE stddev_pop(HUGEINT) TO PUBLIC;\n"
258 : "create window stddev_pop(val HUGEINT) returns DOUBLE\n"
259 : " external name \"sql\".\"stdevp\";\n"
260 : "GRANT EXECUTE ON WINDOW stddev_pop(HUGEINT) TO PUBLIC;\n"
261 : "create aggregate var_samp(val HUGEINT) returns DOUBLE\n"
262 : " external name \"aggr\".\"variance\";\n"
263 : "GRANT EXECUTE ON AGGREGATE var_samp(HUGEINT) TO PUBLIC;\n"
264 : "create window var_samp(val HUGEINT) returns DOUBLE\n"
265 : " external name \"sql\".\"variance\";\n"
266 : "GRANT EXECUTE ON WINDOW var_samp(HUGEINT) TO PUBLIC;\n"
267 : "create aggregate covar_samp(e1 HUGEINT, e2 HUGEINT) returns DOUBLE\n"
268 : " external name \"aggr\".\"covariance\";\n"
269 : "GRANT EXECUTE ON AGGREGATE covar_samp(HUGEINT, HUGEINT) TO PUBLIC;\n"
270 : "create window covar_samp(e1 HUGEINT, e2 HUGEINT) returns DOUBLE\n"
271 : " external name \"sql\".\"covariance\";\n"
272 : "GRANT EXECUTE ON WINDOW covar_samp(HUGEINT, HUGEINT) TO PUBLIC;\n"
273 : "create aggregate var_pop(val HUGEINT) returns DOUBLE\n"
274 : " external name \"aggr\".\"variancep\";\n"
275 : "GRANT EXECUTE ON AGGREGATE var_pop(HUGEINT) TO PUBLIC;\n"
276 : "create window var_pop(val HUGEINT) returns DOUBLE\n"
277 : " external name \"sql\".\"variancep\";\n"
278 : "GRANT EXECUTE ON WINDOW var_pop(HUGEINT) TO PUBLIC;\n"
279 : "create aggregate covar_pop(e1 HUGEINT, e2 HUGEINT) returns DOUBLE\n"
280 : " external name \"aggr\".\"covariancep\";\n"
281 : "GRANT EXECUTE ON AGGREGATE covar_pop(HUGEINT, HUGEINT) TO PUBLIC;\n"
282 : "create window covar_pop(e1 HUGEINT, e2 HUGEINT) returns DOUBLE\n"
283 : " external name \"sql\".\"covariancep\";\n"
284 : "GRANT EXECUTE ON WINDOW covar_pop(HUGEINT, HUGEINT) TO PUBLIC;\n"
285 : "create aggregate median(val HUGEINT) returns HUGEINT\n"
286 : " external name \"aggr\".\"median\";\n"
287 : "GRANT EXECUTE ON AGGREGATE median(HUGEINT) TO PUBLIC;\n"
288 : "create aggregate quantile(val HUGEINT, q DOUBLE) returns HUGEINT\n"
289 : " external name \"aggr\".\"quantile\";\n"
290 : "GRANT EXECUTE ON AGGREGATE quantile(HUGEINT, DOUBLE) TO PUBLIC;\n"
291 : "create aggregate median_avg(val HUGEINT) returns DOUBLE\n"
292 : " external name \"aggr\".\"median_avg\";\n"
293 : "GRANT EXECUTE ON AGGREGATE median_avg(HUGEINT) TO PUBLIC;\n"
294 : "create aggregate quantile_avg(val HUGEINT, q DOUBLE) returns DOUBLE\n"
295 : " external name \"aggr\".\"quantile_avg\";\n"
296 : "GRANT EXECUTE ON AGGREGATE quantile_avg(HUGEINT, DOUBLE) TO PUBLIC;\n"
297 : "create aggregate corr(e1 HUGEINT, e2 HUGEINT) returns DOUBLE\n"
298 : " external name \"aggr\".\"corr\";\n"
299 : "GRANT EXECUTE ON AGGREGATE corr(HUGEINT, HUGEINT) TO PUBLIC;\n"
300 : "create window corr(e1 HUGEINT, e2 HUGEINT) returns DOUBLE\n"
301 : " external name \"sql\".\"corr\";\n"
302 : "GRANT EXECUTE ON WINDOW corr(HUGEINT, HUGEINT) TO PUBLIC;\n"
303 : "create aggregate median(val DECIMAL(38)) returns DECIMAL(38)\n"
304 : " external name \"aggr\".\"median\";\n"
305 : "GRANT EXECUTE ON AGGREGATE median(DECIMAL(38)) TO PUBLIC;\n"
306 : "create aggregate median_avg(val DECIMAL(38)) returns DOUBLE\n"
307 : " external name \"aggr\".\"median_avg\";\n"
308 : "GRANT EXECUTE ON AGGREGATE median_avg(DECIMAL(38)) TO PUBLIC;\n"
309 : "create aggregate quantile(val DECIMAL(38), q DOUBLE) returns DECIMAL(38)\n"
310 : " external name \"aggr\".\"quantile\";\n"
311 : "GRANT EXECUTE ON AGGREGATE quantile(DECIMAL(38), DOUBLE) TO PUBLIC;\n"
312 : "create aggregate quantile_avg(val DECIMAL(38), q DOUBLE) returns DOUBLE\n"
313 : " external name \"aggr\".\"quantile_avg\";\n"
314 : "GRANT EXECUTE ON AGGREGATE quantile_avg(DECIMAL(38), DOUBLE) TO PUBLIC;\n");
315 :
316 : /* 40_json_hge.sql */
317 8 : pos += snprintf(buf + pos, bufsize - pos,
318 : "create function json.filter(js json, name hugeint)\n"
319 : "returns json external name json.filter;\n"
320 : "GRANT EXECUTE ON FUNCTION json.filter(json, hugeint) TO PUBLIC;\n");
321 :
322 8 : pos += snprintf(buf + pos, bufsize - pos,
323 : "update sys.functions set system = true where system <> true and name in ('generate_series') and schema_id = 2000 and type = %d;\n"
324 : "update sys.functions set system = true where system <> true and name in ('stddev_samp', 'stddev_pop', 'var_samp', 'covar_samp', 'var_pop', 'covar_pop', 'median', 'median_avg', 'quantile', 'quantile_avg', 'corr') and schema_id = 2000 and type = %d;\n"
325 : "update sys.functions set system = true where system <> true and name in ('stddev_samp', 'stddev_pop', 'var_samp', 'covar_samp', 'var_pop', 'covar_pop', 'corr') and schema_id = 2000 and type = %d;\n"
326 : "update sys.functions set system = true where system <> true and name = 'filter' and schema_id = (select id from sys.schemas where name = 'json') and type = %d;\n",
327 : (int) F_UNION, (int) F_AGGR, (int) F_ANALYTIC, (int) F_FUNC);
328 :
329 8 : assert(pos < bufsize);
330 :
331 8 : printf("Running database upgrade commands:\n%s\n", buf);
332 8 : fflush(stdout);
333 8 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
334 8 : GDKfree(buf);
335 8 : return err; /* usually MAL_SUCCEED */
336 : }
337 : #endif
338 :
339 : #ifdef HAVE_SHP
340 : static str
341 0 : sql_create_shp(Client c)
342 : {
343 : //Create the new SHPload procedures
344 0 : const char query[] = "create procedure SHPLoad(fname string, schemaname string, tablename string) external name shp.load;\n"
345 : "create procedure SHPLoad(fname string, tablename string) external name shp.load;\n"
346 : "update sys.functions set system = true where schema_id = 2000 and name in ('shpload');";
347 0 : printf("Running database upgrade commands:\n%s\n", query);
348 0 : fflush(stdout);
349 0 : return SQLstatementIntern(c, query, "update", true, false, NULL);
350 : }
351 : #endif
352 :
353 : static str
354 0 : sql_drop_shp(Client c)
355 : {
356 : //Drop the old SHP procedures (upgrade from version before shpload upgrade)
357 0 : const char query[] = "drop procedure if exists SHPattach(string) cascade;\n"
358 : "drop procedure if exists SHPload(integer) cascade;\n"
359 : "drop procedure if exists SHPload(integer, geometry) cascade;\n";
360 0 : printf("Running database upgrade commands:\n%s\n", query);
361 0 : fflush(stdout);
362 0 : return SQLstatementIntern(c, query, "update", true, false, NULL);
363 : }
364 :
365 : static str
366 96 : sql_update_jan2022(Client c, mvc *sql)
367 : {
368 96 : sql_subtype tp;
369 96 : size_t bufsize = 65536, pos = 0;
370 96 : char *buf = NULL, *err = NULL;
371 96 : sql_schema *s = mvc_bind_schema(sql, "sys");
372 96 : sql_table *t;
373 :
374 96 : sql_find_subtype(&tp, "bigint", 0, 0);
375 96 : if (!sql_bind_func(sql, s->base.name, "epoch", &tp, NULL, F_FUNC, true, true)) {
376 96 : sql->session->status = 0; /* if the function was not found clean the error */
377 96 : sql->errstr[0] = '\0';
378 : /* nothing to do */
379 96 : return NULL;
380 : }
381 :
382 0 : if ((buf = GDKmalloc(bufsize)) == NULL)
383 0 : throw(SQL, __func__, SQLSTATE(HY013) MAL_MALLOC_FAIL);
384 :
385 : /* sys.epoch_ms now returns a decimal(18,3) */
386 0 : pos += snprintf(buf + pos, bufsize - pos,
387 : "update sys.args set type = 'decimal', type_digits = 18, type_scale = 3 where func_id in (select id from sys.functions where name = 'epoch_ms' and schema_id = 2000) and number = 0 and type = 'bigint';\n");
388 :
389 : /* 16_tracelog */
390 0 : t = mvc_bind_table(sql, s, "tracelog");
391 0 : t->system = 0; /* make it non-system else the drop view will fail */
392 0 : pos += snprintf(buf + pos, bufsize - pos,
393 : "drop view sys.tracelog cascade;\n"
394 : "drop function sys.tracelog() cascade;\n"
395 : "create function sys.tracelog()\n"
396 : " returns table (\n"
397 : " ticks bigint, -- time in microseconds\n"
398 : " stmt string, -- actual statement executed\n"
399 : " event string -- profiler event executed\n"
400 : " )\n"
401 : " external name sql.dump_trace;\n"
402 : "create view sys.tracelog as select * from sys.tracelog();\n"
403 : "update sys._tables set system = true where system <> true and schema_id = 2000"
404 : " and name = 'tracelog';\n"
405 : "update sys.functions set system = true where system <> true and schema_id = 2000"
406 : " and name = 'tracelog' and type = %d;\n", (int) F_UNION);
407 :
408 : /* 17_temporal.sql */
409 0 : pos += snprintf(buf + pos, bufsize - pos,
410 : "drop function sys.epoch(bigint) cascade;\n");
411 0 : pos += snprintf(buf + pos, bufsize - pos,
412 : "create function sys.epoch(sec DECIMAL(18,3)) "
413 : "returns TIMESTAMP WITH TIME ZONE\n"
414 : "external name mtime.epoch;\n"
415 : "grant execute on function sys.epoch (DECIMAL(18,3)) to public;\n"
416 : "update sys.functions set system = true where system <> true and name in ('epoch') and schema_id = 2000 and type = %d;\n", F_FUNC);
417 :
418 : /* 25_debug.sql */
419 0 : pos += snprintf(buf + pos, bufsize - pos,
420 : "drop function sys.malfunctions() cascade;\n"
421 : "create function sys.malfunctions()\n"
422 : " returns table(\"module\" string, \"function\" string, \"signature\" string, \"address\" string, \"comment\" string)\n"
423 : " external name \"manual\".\"functions\";\n"
424 : "create view sys.malfunctions as select * from sys.malfunctions();\n"
425 : "update sys._tables set system = true where system <> true and schema_id = 2000"
426 : " and name = 'malfunctions';\n"
427 : "update sys.functions set system = true where system <> true and schema_id = 2000"
428 : " and name = 'malfunctions';\n");
429 :
430 : /* 21_dependency_views.sql */
431 0 : t = mvc_bind_table(sql, s, "ids");
432 0 : t->system = 0; /* make it non-system else the drop view will fail */
433 0 : t = mvc_bind_table(sql, s, "dependencies_vw");
434 0 : t->system = 0; /* make it non-system else the drop view will fail */
435 0 : pos += snprintf(buf + pos, bufsize - pos,
436 : "drop view sys.dependencies_vw cascade;\n" /* depends on sys.ids */
437 : "drop view sys.ids cascade;\n"
438 : "CREATE VIEW sys.ids (id, name, schema_id, table_id, table_name, obj_type, sys_table, system) AS\n"
439 : "SELECT id, name, cast(null as int) as schema_id, cast(null as int) as table_id, cast(null as varchar(124)) as table_name, 'author' AS obj_type, 'sys.auths' AS sys_table, (name in ('public','sysadmin','monetdb','.snapshot')) AS system FROM sys.auths UNION ALL\n"
440 : "SELECT id, name, cast(null as int) as schema_id, cast(null as int) as table_id, cast(null as varchar(124)) as table_name, ifthenelse(system, 'system schema', 'schema'), 'sys.schemas', system FROM sys.schemas UNION ALL\n"
441 : "SELECT t.id, name, t.schema_id, t.id as table_id, t.name as table_name, cast(lower(tt.table_type_name) as varchar(40)), 'sys.tables', t.system FROM sys.tables t left outer join sys.table_types tt on t.type = tt.table_type_id UNION ALL\n"
442 : "SELECT c.id, c.name, t.schema_id, c.table_id, t.name as table_name, ifthenelse(t.system, 'system column', 'column'), 'sys._columns', t.system FROM sys._columns c JOIN sys._tables t ON c.table_id = t.id UNION ALL\n"
443 : "SELECT c.id, c.name, t.schema_id, c.table_id, t.name as table_name, 'column', 'tmp._columns', t.system FROM tmp._columns c JOIN tmp._tables t ON c.table_id = t.id UNION ALL\n"
444 : "SELECT k.id, k.name, t.schema_id, k.table_id, t.name as table_name, ifthenelse(t.system, 'system key', 'key'), 'sys.keys', t.system FROM sys.keys k JOIN sys._tables t ON k.table_id = t.id UNION ALL\n"
445 : "SELECT k.id, k.name, t.schema_id, k.table_id, t.name as table_name, 'key', 'tmp.keys', t.system FROM tmp.keys k JOIN tmp._tables t ON k.table_id = t.id UNION ALL\n"
446 : "SELECT i.id, i.name, t.schema_id, i.table_id, t.name as table_name, ifthenelse(t.system, 'system index', 'index'), 'sys.idxs', t.system FROM sys.idxs i JOIN sys._tables t ON i.table_id = t.id UNION ALL\n"
447 : "SELECT i.id, i.name, t.schema_id, i.table_id, t.name as table_name, 'index' , 'tmp.idxs', t.system FROM tmp.idxs i JOIN tmp._tables t ON i.table_id = t.id UNION ALL\n"
448 : "SELECT g.id, g.name, t.schema_id, g.table_id, t.name as table_name, ifthenelse(t.system, 'system trigger', 'trigger'), 'sys.triggers', t.system FROM sys.triggers g JOIN sys._tables t ON g.table_id = t.id UNION ALL\n"
449 : "SELECT g.id, g.name, t.schema_id, g.table_id, t.name as table_name, 'trigger', 'tmp.triggers', t.system FROM tmp.triggers g JOIN tmp._tables t ON g.table_id = t.id UNION ALL\n"
450 : "SELECT f.id, f.name, f.schema_id, cast(null as int) as table_id, cast(null as varchar(124)) as table_name, cast(ifthenelse(f.system, 'system ', '') || lower(ft.function_type_keyword) as varchar(40)), 'sys.functions', f.system FROM sys.functions f left outer join sys.function_types ft on f.type = ft.function_type_id UNION ALL\n"
451 : "SELECT a.id, a.name, f.schema_id, a.func_id as table_id, f.name as table_name, cast(ifthenelse(f.system, 'system ', '') || lower(ft.function_type_keyword) || ' arg' as varchar(44)), 'sys.args', f.system FROM sys.args a JOIN sys.functions f ON a.func_id = f.id left outer join sys.function_types ft on f.type = ft.function_type_id UNION ALL\n"
452 : "SELECT id, name, schema_id, cast(null as int) as table_id, cast(null as varchar(124)) as table_name, 'sequence', 'sys.sequences', false FROM sys.sequences UNION ALL\n"
453 : "SELECT o.id, o.name, pt.schema_id, pt.id, pt.name, 'partition of merge table', 'sys.objects', false FROM sys.objects o JOIN sys._tables pt ON o.sub = pt.id JOIN sys._tables mt ON o.nr = mt.id WHERE mt.type = 3 UNION ALL\n"
454 : "SELECT id, sqlname, schema_id, cast(null as int) as table_id, cast(null as varchar(124)) as table_name, 'type', 'sys.types', (sqlname in ('inet','json','url','uuid')) FROM sys.types WHERE id > 2000\n"
455 : " ORDER BY id;\n"
456 : "GRANT SELECT ON sys.ids TO PUBLIC;\n");
457 0 : pos += snprintf(buf + pos, bufsize - pos,
458 : "CREATE VIEW sys.dependencies_vw AS\n"
459 : "SELECT d.id, i1.obj_type, i1.name,\n"
460 : " d.depend_id as used_by_id, i2.obj_type as used_by_obj_type, i2.name as used_by_name,\n"
461 : " d.depend_type, dt.dependency_type_name\n"
462 : " FROM sys.dependencies d\n"
463 : " JOIN sys.ids i1 ON d.id = i1.id\n"
464 : " JOIN sys.ids i2 ON d.depend_id = i2.id\n"
465 : " JOIN sys.dependency_types dt ON d.depend_type = dt.dependency_type_id\n"
466 : " ORDER BY id, depend_id;\n"
467 : "GRANT SELECT ON sys.dependencies_vw TO PUBLIC;\n");
468 0 : pos += snprintf(buf + pos, bufsize - pos,
469 : "UPDATE sys._tables SET system = true WHERE name in ('ids', 'dependencies_vw') AND schema_id = 2000;\n");
470 :
471 : /* 52_describe.sql; but we need to drop most everything from
472 : * 76_dump.sql first */
473 0 : t = mvc_bind_table(sql, s, "describe_comments");
474 0 : t->system = 0;
475 0 : t = mvc_bind_table(sql, s, "describe_constraints");
476 0 : t->system = 0;
477 0 : t = mvc_bind_table(sql, s, "describe_functions");
478 0 : t->system = 0;
479 0 : t = mvc_bind_table(sql, s, "describe_partition_tables");
480 0 : t->system = 0;
481 0 : t = mvc_bind_table(sql, s, "describe_privileges");
482 0 : t->system = 0;
483 0 : t = mvc_bind_table(sql, s, "describe_sequences");
484 0 : t->system = 0;
485 0 : t = mvc_bind_table(sql, s, "describe_tables");
486 0 : t->system = 0;
487 0 : t = mvc_bind_table(sql, s, "dump_add_schemas_to_users");
488 0 : t->system = 0;
489 0 : t = mvc_bind_table(sql, s, "dump_column_defaults");
490 0 : t->system = 0;
491 0 : t = mvc_bind_table(sql, s, "dump_comments");
492 0 : t->system = 0;
493 0 : t = mvc_bind_table(sql, s, "dump_create_roles");
494 0 : t->system = 0;
495 0 : t = mvc_bind_table(sql, s, "dump_create_schemas");
496 0 : t->system = 0;
497 0 : t = mvc_bind_table(sql, s, "dump_create_users");
498 0 : t->system = 0;
499 0 : t = mvc_bind_table(sql, s, "dump_foreign_keys");
500 0 : t->system = 0;
501 0 : t = mvc_bind_table(sql, s, "dump_functions");
502 0 : t->system = 0;
503 0 : t = mvc_bind_table(sql, s, "dump_grant_user_privileges");
504 0 : t->system = 0;
505 0 : t = mvc_bind_table(sql, s, "dump_indices");
506 0 : t->system = 0;
507 0 : t = mvc_bind_table(sql, s, "dump_partition_tables");
508 0 : t->system = 0;
509 0 : t = mvc_bind_table(sql, s, "dump_privileges");
510 0 : t->system = 0;
511 0 : t = mvc_bind_table(sql, s, "dump_sequences");
512 0 : t->system = 0;
513 0 : t = mvc_bind_table(sql, s, "dump_start_sequences");
514 0 : t->system = 0;
515 0 : t = mvc_bind_table(sql, s, "dump_table_constraint_type");
516 0 : t->system = 0;
517 0 : t = mvc_bind_table(sql, s, "dump_tables");
518 0 : t->system = 0;
519 0 : t = mvc_bind_table(sql, s, "dump_triggers");
520 0 : t->system = 0;
521 0 : t = mvc_bind_table(sql, s, "dump_user_defined_types");
522 0 : t->system = 0;
523 0 : t = mvc_bind_table(sql, s, "fully_qualified_functions");
524 0 : t->system = 0;
525 0 : pos += snprintf(buf + pos, bufsize - pos,
526 : /* drop dependent stuff from 76_dump.sql */
527 : "drop function sys.dump_database(boolean) cascade;\n"
528 : "drop procedure sys.dump_table_data() cascade;\n"
529 : "drop procedure sys._dump_table_data(string, string) cascade;\n"
530 : "drop function sys.prepare_esc(string, string) cascade;\n"
531 : "drop function sys.esc(string) cascade;\n"
532 : "drop view sys.dump_privileges cascade;\n"
533 : "drop view sys.dump_user_defined_types cascade;\n"
534 : "drop view sys.dump_comments cascade;\n"
535 : "drop view sys.dump_triggers cascade;\n"
536 : "drop view sys.dump_tables cascade;\n"
537 : "drop view sys.dump_functions cascade;\n"
538 : "drop view sys.dump_start_sequences cascade;\n"
539 : "drop view sys.dump_sequences cascade;\n"
540 : "drop view sys.dump_partition_tables cascade;\n"
541 : "drop view sys.dump_foreign_keys cascade;\n"
542 : "drop view sys.dump_column_defaults cascade;\n"
543 : "drop view sys.dump_indices cascade;\n"
544 : "drop view sys.dump_table_constraint_type cascade;\n"
545 : "drop view sys.dump_grant_user_privileges cascade;\n"
546 : "drop view sys.dump_add_schemas_to_users cascade;\n"
547 : "drop view sys.dump_create_schemas cascade;\n"
548 : "drop view sys.dump_create_users cascade;\n"
549 : "drop view sys.dump_create_roles cascade;\n"
550 :
551 : "drop view sys.describe_functions cascade;\n"
552 : "drop view sys.describe_partition_tables cascade;\n"
553 : "drop view sys.describe_privileges cascade;\n"
554 : "drop view sys.fully_qualified_functions cascade;\n"
555 : "drop view sys.describe_comments cascade;\n"
556 : "drop view sys.describe_tables cascade;\n"
557 : "drop view sys.describe_sequences cascade;\n"
558 : "drop function sys.schema_guard(string, string, string) cascade;\n"
559 : "drop function sys.get_remote_table_expressions(string, string) cascade;\n"
560 : "drop function sys.get_merge_table_partition_expressions(int) cascade;\n"
561 : "drop view sys.describe_constraints cascade;\n"
562 : "drop function sys.alter_table(string, string) cascade;\n"
563 : "drop function sys.FQN(string, string) cascade;\n"
564 : "drop function sys.sq(string) cascade;\n");
565 0 : pos += snprintf(buf + pos, bufsize - pos,
566 : "CREATE FUNCTION sys.SQ (s STRING) RETURNS STRING BEGIN RETURN '''' || sys.replace(s,'''','''''') || ''''; END;\n"
567 : "CREATE FUNCTION sys.FQN(s STRING, t STRING) RETURNS STRING BEGIN RETURN '\"' || sys.replace(s,'\"','\"\"') || '\".\"' || sys.replace(t,'\"','\"\"') || '\"'; END;\n"
568 : "CREATE FUNCTION sys.schema_guard(sch STRING, nme STRING, stmt STRING) RETURNS STRING BEGIN\n"
569 : "RETURN\n"
570 : " SELECT sys.replace_first(stmt, '(\\\\s*\"?' || sch || '\"?\\\\s*\\\\.|)\\\\s*\"?' || nme || '\"?\\\\s*', ' ' || sys.FQN(sch, nme) || ' ', 'imsx');\n"
571 : "END;\n"
572 : "CREATE VIEW sys.describe_constraints AS\n"
573 : " SELECT\n"
574 : " s.name sch,\n"
575 : " t.name tbl,\n"
576 : " kc.name col,\n"
577 : " k.name con,\n"
578 : " CASE k.type WHEN 0 THEN 'PRIMARY KEY' WHEN 1 THEN 'UNIQUE' END tpe\n"
579 : " FROM sys.schemas s, sys._tables t, sys.objects kc, sys.keys k\n"
580 : " WHERE kc.id = k.id\n"
581 : " AND k.table_id = t.id\n"
582 : " AND s.id = t.schema_id\n"
583 : " AND t.system = FALSE\n"
584 : " AND k.type in (0, 1);\n"
585 : "CREATE FUNCTION sys.get_merge_table_partition_expressions(tid INT) RETURNS STRING\n"
586 : "BEGIN\n"
587 : " RETURN\n"
588 : " SELECT\n"
589 : " CASE WHEN tp.table_id IS NOT NULL THEN\n"
590 : " ' PARTITION BY ' ||\n"
591 : " ifthenelse(bit_and(tp.type, 2) = 2, 'VALUES ', 'RANGE ') ||\n"
592 : " CASE\n"
593 : " WHEN bit_and(tp.type, 4) = 4\n"
594 : " THEN 'ON ' || '(' || (SELECT sys.DQ(c.name) || ')' FROM sys.columns c WHERE c.id = tp.column_id)\n"
595 : " ELSE 'USING ' || '(' || tp.expression || ')'\n"
596 : " END\n"
597 : " ELSE\n"
598 : " ''\n"
599 : " END\n"
600 : " FROM (VALUES (tid)) t(id) LEFT JOIN sys.table_partitions tp ON t.id = tp.table_id;\n"
601 : "END;\n"
602 : "CREATE FUNCTION sys.get_remote_table_expressions(s STRING, t STRING) RETURNS STRING BEGIN\n"
603 : " RETURN SELECT ' ON ' || sys.SQ(uri) || ' WITH USER ' || sys.SQ(username) || ' ENCRYPTED PASSWORD ' || sys.SQ(\"hash\") FROM sys.remote_table_credentials(s ||'.' || t);\n"
604 : "END;\n"
605 : "CREATE VIEW sys.describe_tables AS\n"
606 : " SELECT\n"
607 : " t.id o,\n"
608 : " s.name sch,\n"
609 : " t.name tab,\n"
610 : " ts.table_type_name typ,\n"
611 : " (SELECT\n"
612 : " ' (' ||\n"
613 : " GROUP_CONCAT(\n"
614 : " sys.DQ(c.name) || ' ' ||\n"
615 : " sys.describe_type(c.type, c.type_digits, c.type_scale) ||\n"
616 : " ifthenelse(c.\"null\" = 'false', ' NOT NULL', '')\n"
617 : " , ', ') || ')'\n"
618 : " FROM sys._columns c\n"
619 : " WHERE c.table_id = t.id) col,\n"
620 : " CASE ts.table_type_name\n"
621 : " WHEN 'REMOTE TABLE' THEN\n"
622 : " sys.get_remote_table_expressions(s.name, t.name)\n"
623 : " WHEN 'MERGE TABLE' THEN\n"
624 : " sys.get_merge_table_partition_expressions(t.id)\n"
625 : " WHEN 'VIEW' THEN\n"
626 : " sys.schema_guard(s.name, t.name, t.query)\n"
627 : " ELSE\n"
628 : " ''\n"
629 : " END opt\n"
630 : " FROM sys.schemas s, sys.table_types ts, sys.tables t\n"
631 : " WHERE ts.table_type_name IN ('TABLE', 'VIEW', 'MERGE TABLE', 'REMOTE TABLE', 'REPLICA TABLE')\n"
632 : " AND t.system = FALSE\n"
633 : " AND s.id = t.schema_id\n"
634 : " AND ts.table_type_id = t.type\n"
635 : " AND s.name <> 'tmp';\n"
636 : "CREATE VIEW sys.fully_qualified_functions AS\n"
637 : " WITH fqn(id, tpe, sig, num) AS\n"
638 : " (\n"
639 : " SELECT\n"
640 : " f.id,\n"
641 : " ft.function_type_keyword,\n"
642 : " CASE WHEN a.type IS NULL THEN\n"
643 : " sys.fqn(s.name, f.name) || '()'\n"
644 : " ELSE\n"
645 : " sys.fqn(s.name, f.name) || '(' || group_concat(sys.describe_type(a.type, a.type_digits, a.type_scale), ',') OVER (PARTITION BY f.id ORDER BY a.number) || ')'\n"
646 : " END,\n"
647 : " a.number\n"
648 : " FROM sys.schemas s, sys.function_types ft, sys.functions f LEFT JOIN sys.args a ON f.id = a.func_id\n"
649 : " WHERE s.id= f.schema_id AND f.type = ft.function_type_id\n"
650 : " )\n"
651 : " SELECT\n"
652 : " fqn1.id id,\n"
653 : " fqn1.tpe tpe,\n"
654 : " fqn1.sig nme\n"
655 : " FROM\n"
656 : " fqn fqn1 JOIN (SELECT id, max(num) FROM fqn GROUP BY id) fqn2(id, num)\n"
657 : " ON fqn1.id = fqn2.id AND (fqn1.num = fqn2.num OR fqn1.num IS NULL AND fqn2.num is NULL);\n"
658 : "CREATE VIEW sys.describe_comments AS\n"
659 : " SELECT\n"
660 : " o.id id,\n"
661 : " o.tpe tpe,\n"
662 : " o.nme fqn,\n"
663 : " c.remark rem\n"
664 : " FROM (\n"
665 : " SELECT id, 'SCHEMA', sys.DQ(name) FROM sys.schemas\n"
666 : " UNION ALL\n"
667 : " SELECT t.id, ifthenelse(ts.table_type_name = 'VIEW', 'VIEW', 'TABLE'), sys.FQN(s.name, t.name)\n"
668 : " FROM sys.schemas s JOIN sys.tables t ON s.id = t.schema_id JOIN sys.table_types ts ON t.type = ts.table_type_id\n"
669 : " WHERE s.name <> 'tmp'\n"
670 : " UNION ALL\n"
671 : " SELECT c.id, 'COLUMN', sys.FQN(s.name, t.name) || '.' || sys.DQ(c.name) FROM sys.columns c, sys.tables t, sys.schemas s WHERE c.table_id = t.id AND t.schema_id = s.id\n"
672 : " UNION ALL\n"
673 : " SELECT idx.id, 'INDEX', sys.FQN(s.name, idx.name) FROM sys.idxs idx, sys._tables t, sys.schemas s WHERE idx.table_id = t.id AND t.schema_id = s.id\n"
674 : " UNION ALL\n"
675 : " SELECT seq.id, 'SEQUENCE', sys.FQN(s.name, seq.name) FROM sys.sequences seq, sys.schemas s WHERE seq.schema_id = s.id\n"
676 : " UNION ALL\n"
677 : " SELECT f.id, ft.function_type_keyword, qf.nme FROM sys.functions f, sys.function_types ft, sys.schemas s, sys.fully_qualified_functions qf WHERE f.type = ft.function_type_id AND f.schema_id = s.id AND qf.id = f.id\n"
678 : " ) AS o(id, tpe, nme)\n"
679 : " JOIN sys.comments c ON c.id = o.id;\n"
680 : "CREATE VIEW sys.describe_privileges AS\n"
681 : " SELECT\n"
682 : " CASE\n"
683 : " WHEN o.tpe IS NULL AND pc.privilege_code_name = 'SELECT' THEN --GLOBAL privileges: SELECT maps to COPY FROM\n"
684 : " 'COPY FROM'\n"
685 : " WHEN o.tpe IS NULL AND pc.privilege_code_name = 'UPDATE' THEN --GLOBAL privileges: UPDATE maps to COPY INTO\n"
686 : " 'COPY INTO'\n"
687 : " ELSE\n"
688 : " o.nme\n"
689 : " END o_nme,\n"
690 : " coalesce(o.tpe, 'GLOBAL') o_tpe,\n"
691 : " pc.privilege_code_name p_nme,\n"
692 : " a.name a_nme,\n"
693 : " g.name g_nme,\n"
694 : " p.grantable grantable\n"
695 : " FROM\n"
696 : " sys.privileges p LEFT JOIN\n"
697 : " (\n"
698 : " SELECT t.id, s.name || '.' || t.name , 'TABLE'\n"
699 : " from sys.schemas s, sys.tables t where s.id = t.schema_id\n"
700 : " UNION ALL\n"
701 : " SELECT c.id, s.name || '.' || t.name || '.' || c.name, 'COLUMN'\n"
702 : " FROM sys.schemas s, sys.tables t, sys.columns c where s.id = t.schema_id AND t.id = c.table_id\n"
703 : " UNION ALL\n"
704 : " SELECT f.id, f.nme, f.tpe\n"
705 : " FROM sys.fully_qualified_functions f\n"
706 : " ) o(id, nme, tpe) ON o.id = p.obj_id,\n"
707 : " sys.privilege_codes pc,\n"
708 : " auths a, auths g\n"
709 : " WHERE\n"
710 : " p.privileges = pc.privilege_code_id AND\n"
711 : " p.auth_id = a.id AND\n"
712 : " p.grantor = g.id;\n"
713 : "CREATE VIEW sys.describe_partition_tables AS\n"
714 : " SELECT \n"
715 : " m_sch,\n"
716 : " m_tbl,\n"
717 : " p_sch,\n"
718 : " p_tbl,\n"
719 : " CASE\n"
720 : " WHEN p_raw_type IS NULL THEN 'READ ONLY'\n"
721 : " WHEN (p_raw_type = 'VALUES' AND pvalues IS NULL) OR (p_raw_type = 'RANGE' AND minimum IS NULL AND maximum IS NULL AND with_nulls) THEN 'FOR NULLS'\n"
722 : " ELSE p_raw_type\n"
723 : " END AS tpe,\n"
724 : " pvalues,\n"
725 : " minimum,\n"
726 : " maximum,\n"
727 : " with_nulls\n"
728 : " FROM \n"
729 : " (WITH\n"
730 : " tp(\"type\", table_id) AS\n"
731 : " (SELECT ifthenelse((table_partitions.\"type\" & 2) = 2, 'VALUES', 'RANGE'), table_partitions.table_id FROM sys.table_partitions),\n"
732 : " subq(m_tid, p_mid, \"type\", m_sch, m_tbl, p_sch, p_tbl) AS\n"
733 : " (SELECT m_t.id, p_m.id, m_t.\"type\", m_s.name, m_t.name, p_s.name, p_m.name\n"
734 : " FROM sys.schemas m_s, sys._tables m_t, sys.dependencies d, sys.schemas p_s, sys._tables p_m\n"
735 : " WHERE m_t.\"type\" IN (3, 6)\n"
736 : " AND m_t.schema_id = m_s.id\n"
737 : " AND m_s.name <> 'tmp'\n"
738 : " AND m_t.system = FALSE\n"
739 : " AND m_t.id = d.depend_id\n"
740 : " AND d.id = p_m.id\n"
741 : " AND p_m.schema_id = p_s.id\n"
742 : " ORDER BY m_t.id, p_m.id)\n"
743 : " SELECT\n"
744 : " subq.m_sch,\n"
745 : " subq.m_tbl,\n"
746 : " subq.p_sch,\n"
747 : " subq.p_tbl,\n"
748 : " tp.\"type\" AS p_raw_type,\n"
749 : " CASE WHEN tp.\"type\" = 'VALUES'\n"
750 : " THEN (SELECT GROUP_CONCAT(vp.value, ',') FROM sys.value_partitions vp WHERE vp.table_id = subq.p_mid)\n"
751 : " ELSE NULL\n"
752 : " END AS pvalues,\n"
753 : " CASE WHEN tp.\"type\" = 'RANGE'\n"
754 : " THEN (SELECT minimum FROM sys.range_partitions rp WHERE rp.table_id = subq.p_mid)\n"
755 : " ELSE NULL\n"
756 : " END AS minimum,\n"
757 : " CASE WHEN tp.\"type\" = 'RANGE'\n"
758 : " THEN (SELECT maximum FROM sys.range_partitions rp WHERE rp.table_id = subq.p_mid)\n"
759 : " ELSE NULL\n"
760 : " END AS maximum,\n"
761 : " CASE WHEN tp.\"type\" = 'VALUES'\n"
762 : " THEN EXISTS(SELECT vp.value FROM sys.value_partitions vp WHERE vp.table_id = subq.p_mid AND vp.value IS NULL)\n"
763 : " ELSE (SELECT rp.with_nulls FROM sys.range_partitions rp WHERE rp.table_id = subq.p_mid)\n"
764 : " END AS with_nulls\n"
765 : " FROM \n"
766 : " subq LEFT OUTER JOIN tp\n"
767 : " ON subq.m_tid = tp.table_id) AS tmp_pi;\n"
768 : "CREATE VIEW sys.describe_functions AS\n"
769 : " WITH func_args_all(func_id, number, max_number, func_arg) AS\n"
770 : " (\n"
771 : " SELECT\n"
772 : " func_id,\n"
773 : " number,\n"
774 : " max(number) OVER (PARTITION BY func_id ORDER BY number DESC),\n"
775 : " group_concat(sys.dq(name) || ' ' || sys.describe_type(type, type_digits, type_scale),', ') OVER (PARTITION BY func_id ORDER BY number)\n"
776 : " FROM sys.args\n"
777 : " WHERE inout = 1\n"
778 : " ),\n"
779 : " func_args(func_id, func_arg) AS\n"
780 : " (\n"
781 : " SELECT func_id, func_arg\n"
782 : " FROM func_args_all\n"
783 : " WHERE number = max_number\n"
784 : " ),\n"
785 : " func_rets_all(func_id, number, max_number, func_ret, func_ret_type) AS\n"
786 : " (\n"
787 : " SELECT\n"
788 : " func_id,\n"
789 : " number,\n"
790 : " max(number) OVER (PARTITION BY func_id ORDER BY number DESC),\n"
791 : " group_concat(sys.dq(name) || ' ' || sys.describe_type(type, type_digits, type_scale),', ') OVER (PARTITION BY func_id ORDER BY number),\n"
792 : " group_concat(sys.describe_type(type, type_digits, type_scale),', ') OVER (PARTITION BY func_id ORDER BY number)\n"
793 : " FROM sys.args\n"
794 : " WHERE inout = 0\n"
795 : " ),\n"
796 : " func_rets(func_id, func_ret, func_ret_type) AS\n"
797 : " (\n"
798 : " SELECT\n"
799 : " func_id,\n"
800 : " func_ret,\n"
801 : " func_ret_type\n"
802 : " FROM func_rets_all\n"
803 : " WHERE number = max_number\n"
804 : " )\n"
805 : " SELECT\n"
806 : " f.id o,\n"
807 : " s.name sch,\n"
808 : " f.name fun,\n"
809 : " CASE WHEN f.language IN (1, 2) THEN f.func ELSE 'CREATE ' || ft.function_type_keyword || ' ' || sys.FQN(s.name, f.name) || '(' || coalesce(fa.func_arg, '') || ')' || CASE WHEN f.type = 5 THEN ' RETURNS TABLE (' || coalesce(fr.func_ret, '') || ')' WHEN f.type IN (1,3) THEN ' RETURNS ' || fr.func_ret_type ELSE '' END || CASE WHEN fl.language_keyword IS NULL THEN '' ELSE ' LANGUAGE ' || fl.language_keyword END || ' ' || f.func END def\n"
810 : " FROM sys.functions f\n"
811 : " LEFT OUTER JOIN func_args fa ON fa.func_id = f.id\n"
812 : " LEFT OUTER JOIN func_rets fr ON fr.func_id = f.id\n"
813 : " JOIN sys.schemas s ON f.schema_id = s.id\n"
814 : " JOIN sys.function_types ft ON f.type = ft.function_type_id\n"
815 : " LEFT OUTER JOIN sys.function_languages fl ON f.language = fl.language_id\n"
816 : " WHERE s.name <> 'tmp' AND NOT f.system;\n"
817 : "CREATE VIEW sys.describe_sequences AS\n"
818 : " SELECT\n"
819 : " s.name sch,\n"
820 : " seq.name seq,\n"
821 : " seq.\"start\" s,\n"
822 : " get_value_for(s.name, seq.name) rs,\n"
823 : " seq.\"minvalue\" mi,\n"
824 : " seq.\"maxvalue\" ma,\n"
825 : " seq.\"increment\" inc,\n"
826 : " seq.\"cacheinc\" cache,\n"
827 : " seq.\"cycle\" cycle,\n"
828 : " CASE WHEN seq.\"minvalue\" = -9223372036854775807 AND seq.\"increment\" > 0 AND seq.\"start\" = 1 THEN TRUE ELSE FALSE END nomin,\n"
829 : " CASE WHEN seq.\"maxvalue\" = 9223372036854775807 AND seq.\"increment\" < 0 AND seq.\"start\" = -1 THEN TRUE ELSE FALSE END nomax,\n"
830 : " CASE\n"
831 : " WHEN seq.\"minvalue\" = 0 AND seq.\"increment\" > 0 THEN NULL\n"
832 : " WHEN seq.\"minvalue\" <> -9223372036854775807 THEN seq.\"minvalue\"\n"
833 : " ELSE\n"
834 : " CASE\n"
835 : " WHEN seq.\"increment\" < 0 THEN NULL\n"
836 : " ELSE CASE WHEN seq.\"start\" = 1 THEN NULL ELSE seq.\"maxvalue\" END\n"
837 : " END\n"
838 : " END rmi,\n"
839 : " CASE\n"
840 : " WHEN seq.\"maxvalue\" = 0 AND seq.\"increment\" < 0 THEN NULL\n"
841 : " WHEN seq.\"maxvalue\" <> 9223372036854775807 THEN seq.\"maxvalue\"\n"
842 : " ELSE\n"
843 : " CASE\n"
844 : " WHEN seq.\"increment\" > 0 THEN NULL\n"
845 : " ELSE CASE WHEN seq.\"start\" = -1 THEN NULL ELSE seq.\"maxvalue\" END\n"
846 : " END\n"
847 : " END rma\n"
848 : " FROM sys.sequences seq, sys.schemas s\n"
849 : " WHERE s.id = seq.schema_id\n"
850 : " AND s.name <> 'tmp'\n"
851 : " ORDER BY s.name, seq.name;\n"
852 : "GRANT SELECT ON sys.describe_constraints TO PUBLIC;\n"
853 : "GRANT SELECT ON sys.describe_indices TO PUBLIC;\n"
854 : "GRANT SELECT ON sys.describe_column_defaults TO PUBLIC;\n"
855 : "GRANT SELECT ON sys.describe_foreign_keys TO PUBLIC;\n"
856 : "GRANT SELECT ON sys.describe_tables TO PUBLIC;\n"
857 : "GRANT SELECT ON sys.describe_triggers TO PUBLIC;\n"
858 : "GRANT SELECT ON sys.describe_comments TO PUBLIC;\n"
859 : "GRANT SELECT ON sys.fully_qualified_functions TO PUBLIC;\n"
860 : "GRANT SELECT ON sys.describe_privileges TO PUBLIC;\n"
861 : "GRANT SELECT ON sys.describe_user_defined_types TO PUBLIC;\n"
862 : "GRANT SELECT ON sys.describe_partition_tables TO PUBLIC;\n"
863 : "GRANT SELECT ON sys.describe_sequences TO PUBLIC;\n"
864 : "GRANT SELECT ON sys.describe_functions TO PUBLIC;\n");
865 0 : pos += snprintf(buf + pos, bufsize - pos,
866 : "update sys.functions set system = true where system <> true and name in ('sq', 'fqn', 'get_merge_table_partition_expressions', 'get_remote_table_expressions', 'schema_guard') and schema_id = 2000 and type = %d;\n", F_FUNC);
867 0 : pos += snprintf(buf + pos, bufsize - pos,
868 : "update sys._tables set system = true where name in ('describe_constraints', 'describe_tables', 'fully_qualified_functions', 'describe_comments', 'describe_privileges', 'describe_partition_tables', 'describe_sequences', 'describe_functions') AND schema_id = 2000;\n");
869 :
870 : /* 76_dump.sql (most everything already dropped) */
871 0 : pos += snprintf(buf + pos, bufsize - pos,
872 : "CREATE VIEW sys.dump_create_roles AS\n"
873 : " SELECT\n"
874 : " 'CREATE ROLE ' || sys.dq(name) || ';' stmt,\n"
875 : " name user_name\n"
876 : " FROM sys.auths\n"
877 : " WHERE name NOT IN (SELECT name FROM sys.db_user_info)\n"
878 : " AND grantor <> 0;\n"
879 : "CREATE VIEW sys.dump_create_users AS\n"
880 : " SELECT\n"
881 : " 'CREATE USER ' || sys.dq(ui.name) || ' WITH ENCRYPTED PASSWORD ' ||\n"
882 : " sys.sq(sys.password_hash(ui.name)) ||\n"
883 : " ' NAME ' || sys.sq(ui.fullname) || ' SCHEMA sys' || ifthenelse(ui.schema_path = '\"sys\"', '', ' SCHEMA PATH ' || sys.sq(ui.schema_path)) || ';' stmt,\n"
884 : " ui.name user_name\n"
885 : " FROM sys.db_user_info ui, sys.schemas s\n"
886 : " WHERE ui.default_schema = s.id\n"
887 : " AND ui.name <> 'monetdb'\n"
888 : " AND ui.name <> '.snapshot';\n"
889 : "CREATE VIEW sys.dump_create_schemas AS\n"
890 : " SELECT\n"
891 : " 'CREATE SCHEMA ' || sys.dq(s.name) || ifthenelse(a.name <> 'sysadmin', ' AUTHORIZATION ' || sys.dq(a.name), ' ') || ';' stmt,\n"
892 : " s.name schema_name\n"
893 : " FROM sys.schemas s, sys.auths a\n"
894 : " WHERE s.authorization = a.id AND s.system = FALSE;\n"
895 : "CREATE VIEW sys.dump_add_schemas_to_users AS\n"
896 : " SELECT\n"
897 : " 'ALTER USER ' || sys.dq(ui.name) || ' SET SCHEMA ' || sys.dq(s.name) || ';' stmt,\n"
898 : " s.name schema_name,\n"
899 : " ui.name user_name\n"
900 : " FROM sys.db_user_info ui, sys.schemas s\n"
901 : " WHERE ui.default_schema = s.id\n"
902 : " AND ui.name <> 'monetdb'\n"
903 : " AND ui.name <> '.snapshot'\n"
904 : " AND s.name <> 'sys';\n"
905 : "CREATE VIEW sys.dump_grant_user_privileges AS\n"
906 : " SELECT\n"
907 : " 'GRANT ' || sys.dq(a2.name) || ' ' || ifthenelse(a1.name = 'public', 'PUBLIC', sys.dq(a1.name)) || ';' stmt,\n"
908 : " a2.name grantee,\n"
909 : " a1.name grantor\n"
910 : " FROM sys.auths a1, sys.auths a2, sys.user_role ur\n"
911 : " WHERE a1.id = ur.login_id AND a2.id = ur.role_id;\n"
912 : "CREATE VIEW sys.dump_table_constraint_type AS\n"
913 : " SELECT\n"
914 : " 'ALTER TABLE ' || sys.FQN(sch, tbl) || ' ADD CONSTRAINT ' || sys.DQ(con) || ' '||\n"
915 : " tpe || ' (' || GROUP_CONCAT(sys.DQ(col), ', ') || ');' stmt,\n"
916 : " sch schema_name,\n"
917 : " tbl table_name,\n"
918 : " con constraint_name\n"
919 : " FROM sys.describe_constraints GROUP BY sch, tbl, con, tpe;\n"
920 : "CREATE VIEW sys.dump_table_grants AS\n"
921 : " WITH table_grants (sname, tname, grantee, grants, grantor, grantable)\n"
922 : " AS (SELECT s.name, t.name, a.name, sum(p.privileges), g.name, p.grantable\n"
923 : " FROM sys.schemas s, sys.tables t, sys.auths a, sys.privileges p, sys.auths g\n"
924 : " WHERE p.obj_id = t.id AND p.auth_id = a.id AND t.schema_id = s.id AND t.system = FALSE AND p.grantor = g.id\n"
925 : " GROUP BY s.name, t.name, a.name, g.name, p.grantable\n"
926 : " ORDER BY s.name, t.name, a.name, g.name, p.grantable)\n"
927 : " SELECT\n"
928 : " 'GRANT ' || pc.privilege_code_name || ' ON TABLE ' || sys.FQN(sname, tname)\n"
929 : " || ' TO ' || ifthenelse(grantee = 'public', 'PUBLIC', sys.dq(grantee))\n"
930 : " || CASE WHEN grantable = 1 THEN ' WITH GRANT OPTION' ELSE '' END || ';' stmt,\n"
931 : " sname schema_name,\n"
932 : " tname table_name,\n"
933 : " grantee\n"
934 : " FROM table_grants LEFT OUTER JOIN sys.privilege_codes pc ON grants = pc.privilege_code_id;\n"
935 : "CREATE VIEW sys.dump_column_grants AS\n"
936 : " SELECT\n"
937 : " 'GRANT ' || pc.privilege_code_name || '(' || sys.dq(c.name) || ') ON ' || sys.FQN(s.name, t.name)\n"
938 : " || ' TO ' || ifthenelse(a.name = 'public', 'PUBLIC', sys.dq(a.name))\n"
939 : " || CASE WHEN p.grantable = 1 THEN ' WITH GRANT OPTION' ELSE '' END || ';' stmt,\n"
940 : " s.name schema_name,\n"
941 : " t.name table_name,\n"
942 : " c.name column_name,\n"
943 : " a.name grantee\n"
944 : " FROM sys.schemas s,\n"
945 : " sys.tables t,\n"
946 : " sys.columns c,\n"
947 : " sys.auths a,\n"
948 : " sys.privileges p,\n"
949 : " sys.auths g,\n"
950 : " sys.privilege_codes pc\n"
951 : " WHERE p.obj_id = c.id\n"
952 : " AND c.table_id = t.id\n"
953 : " AND p.auth_id = a.id\n"
954 : " AND t.schema_id = s.id\n"
955 : " AND NOT t.system\n"
956 : " AND p.grantor = g.id\n"
957 : " AND p.privileges = pc.privilege_code_id\n"
958 : " ORDER BY s.name, t.name, c.name, a.name, g.name, p.grantable;\n"
959 : "CREATE VIEW sys.dump_function_grants AS\n"
960 : " WITH func_args_all(func_id, number, max_number, func_arg) AS\n"
961 : " (SELECT a.func_id,\n"
962 : " a.number,\n"
963 : " max(a.number) OVER (PARTITION BY a.func_id ORDER BY a.number DESC),\n"
964 : " group_concat(sys.describe_type(a.type, a.type_digits, a.type_scale), ', ') OVER (PARTITION BY a.func_id ORDER BY a.number)\n"
965 : " FROM sys.args a\n"
966 : " WHERE a.inout = 1),\n"
967 : " func_args(func_id, func_arg) AS\n"
968 : " (SELECT func_id, func_arg FROM func_args_all WHERE number = max_number)\n"
969 : " SELECT\n"
970 : " 'GRANT ' || pc.privilege_code_name || ' ON ' || ft.function_type_keyword || ' '\n"
971 : " || sys.FQN(s.name, f.name) || '(' || coalesce(fa.func_arg, '') || ') TO '\n"
972 : " || ifthenelse(a.name = 'public', 'PUBLIC', sys.dq(a.name))\n"
973 : " || CASE WHEN p.grantable = 1 THEN ' WITH GRANT OPTION' ELSE '' END || ';' stmt,\n"
974 : " s.name schema_name,\n"
975 : " f.name function_name,\n"
976 : " a.name grantee\n"
977 : " FROM sys.schemas s,\n"
978 : " sys.functions f LEFT OUTER JOIN func_args fa ON f.id = fa.func_id,\n"
979 : " sys.auths a,\n"
980 : " sys.privileges p,\n"
981 : " sys.auths g,\n"
982 : " sys.function_types ft,\n"
983 : " sys.privilege_codes pc\n"
984 : " WHERE s.id = f.schema_id\n"
985 : " AND f.id = p.obj_id\n"
986 : " AND p.auth_id = a.id\n"
987 : " AND p.grantor = g.id\n"
988 : " AND p.privileges = pc.privilege_code_id\n"
989 : " AND f.type = ft.function_type_id\n"
990 : " AND NOT f.system\n"
991 : " ORDER BY s.name, f.name, a.name, g.name, p.grantable;\n"
992 : "CREATE VIEW sys.dump_indices AS\n"
993 : " SELECT\n"
994 : " 'CREATE ' || tpe || ' ' || sys.DQ(ind) || ' ON ' || sys.FQN(sch, tbl) || '(' || GROUP_CONCAT(col) || ');' stmt,\n"
995 : " sch schema_name,\n"
996 : " tbl table_name,\n"
997 : " ind index_name\n"
998 : " FROM sys.describe_indices GROUP BY ind, tpe, sch, tbl;\n"
999 : "CREATE VIEW sys.dump_column_defaults AS\n"
1000 : " SELECT 'ALTER TABLE ' || sys.FQN(sch, tbl) || ' ALTER COLUMN ' || sys.DQ(col) || ' SET DEFAULT ' || def || ';' stmt,\n"
1001 : " sch schema_name,\n"
1002 : " tbl table_name,\n"
1003 : " col column_name\n"
1004 : " FROM sys.describe_column_defaults;\n"
1005 : "CREATE VIEW sys.dump_foreign_keys AS\n"
1006 : " SELECT\n"
1007 : " 'ALTER TABLE ' || sys.FQN(fk_s, fk_t) || ' ADD CONSTRAINT ' || sys.DQ(fk) || ' ' ||\n"
1008 : " 'FOREIGN KEY(' || GROUP_CONCAT(sys.DQ(fk_c), ',') ||') ' ||\n"
1009 : " 'REFERENCES ' || sys.FQN(pk_s, pk_t) || '(' || GROUP_CONCAT(sys.DQ(pk_c), ',') || ') ' ||\n"
1010 : " 'ON DELETE ' || on_delete || ' ON UPDATE ' || on_update ||\n"
1011 : " ';' stmt,\n"
1012 : " fk_s foreign_schema_name,\n"
1013 : " fk_t foreign_table_name,\n"
1014 : " pk_s primary_schema_name,\n"
1015 : " pk_t primary_table_name,\n"
1016 : " fk key_name\n"
1017 : " FROM sys.describe_foreign_keys GROUP BY fk_s, fk_t, pk_s, pk_t, fk, on_delete, on_update;\n"
1018 : "CREATE VIEW sys.dump_partition_tables AS\n"
1019 : " SELECT\n"
1020 : " 'ALTER TABLE ' || sys.FQN(m_sch, m_tbl) || ' ADD TABLE ' || sys.FQN(p_sch, p_tbl) ||\n"
1021 : " CASE \n"
1022 : " WHEN tpe = 'VALUES' THEN ' AS PARTITION IN (' || pvalues || ')'\n"
1023 : " WHEN tpe = 'RANGE' THEN ' AS PARTITION FROM ' || ifthenelse(minimum IS NOT NULL, sys.SQ(minimum), 'RANGE MINVALUE') || ' TO ' || ifthenelse(maximum IS NOT NULL, sys.SQ(maximum), 'RANGE MAXVALUE')\n"
1024 : " WHEN tpe = 'FOR NULLS' THEN ' AS PARTITION FOR NULL VALUES'\n"
1025 : " ELSE ''\n"
1026 : " END ||\n"
1027 : " CASE WHEN tpe in ('VALUES', 'RANGE') AND with_nulls THEN ' WITH NULL VALUES' ELSE '' END ||\n"
1028 : " ';' stmt,\n"
1029 : " m_sch merge_schema_name,\n"
1030 : " m_tbl merge_table_name,\n"
1031 : " p_sch partition_schema_name,\n"
1032 : " p_tbl partition_table_name\n"
1033 : " FROM sys.describe_partition_tables;\n"
1034 : "CREATE VIEW sys.dump_sequences AS\n"
1035 : " SELECT\n"
1036 : " 'CREATE SEQUENCE ' || sys.FQN(sch, seq) || ' AS BIGINT ' ||\n"
1037 : " CASE WHEN \"s\" <> 0 THEN 'START WITH ' || \"rs\" ELSE '' END ||\n"
1038 : " CASE WHEN \"inc\" <> 1 THEN ' INCREMENT BY ' || \"inc\" ELSE '' END ||\n"
1039 : " CASE\n"
1040 : " WHEN nomin THEN ' NO MINVALUE'\n"
1041 : " WHEN rmi IS NOT NULL THEN ' MINVALUE ' || rmi\n"
1042 : " ELSE ''\n"
1043 : " END ||\n"
1044 : " CASE\n"
1045 : " WHEN nomax THEN ' NO MAXVALUE'\n"
1046 : " WHEN rma IS NOT NULL THEN ' MAXVALUE ' || rma\n"
1047 : " ELSE ''\n"
1048 : " END ||\n"
1049 : " CASE WHEN \"cache\" <> 1 THEN ' CACHE ' || \"cache\" ELSE '' END ||\n"
1050 : " CASE WHEN \"cycle\" THEN ' CYCLE' ELSE '' END ||\n"
1051 : " ';' stmt,\n"
1052 : " sch schema_name,\n"
1053 : " seq seqname\n"
1054 : " FROM sys.describe_sequences;\n"
1055 : "CREATE VIEW sys.dump_start_sequences AS\n"
1056 : " SELECT\n"
1057 : " 'UPDATE sys.sequences seq SET start = ' || s ||\n"
1058 : " ' WHERE name = ' || sys.SQ(seq) ||\n"
1059 : " ' AND schema_id = (SELECT s.id FROM sys.schemas s WHERE s.name = ' || sys.SQ(sch) || ');' stmt,\n"
1060 : " sch schema_name,\n"
1061 : " seq sequence_name\n"
1062 : " FROM sys.describe_sequences;\n"
1063 : "CREATE VIEW sys.dump_functions AS\n"
1064 : " SELECT f.o o, sys.schema_guard(f.sch, f.fun, f.def) stmt,\n"
1065 : " f.sch schema_name,\n"
1066 : " f.fun function_name\n"
1067 : " FROM sys.describe_functions f;\n"
1068 : "CREATE VIEW sys.dump_tables AS\n"
1069 : " SELECT\n"
1070 : " t.o o,\n"
1071 : " CASE\n"
1072 : " WHEN t.typ <> 'VIEW' THEN\n"
1073 : " 'CREATE ' || t.typ || ' ' || sys.FQN(t.sch, t.tab) || t.col || t.opt || ';'\n"
1074 : " ELSE\n"
1075 : " t.opt\n"
1076 : " END stmt,\n"
1077 : " t.sch schema_name,\n"
1078 : " t.tab table_name\n"
1079 : " FROM sys.describe_tables t;\n"
1080 : "CREATE VIEW sys.dump_triggers AS\n"
1081 : " SELECT sys.schema_guard(sch, tab, def) stmt,\n"
1082 : " sch schema_name,\n"
1083 : " tab table_name,\n"
1084 : " tri trigger_name\n"
1085 : " FROM sys.describe_triggers;\n"
1086 : "CREATE VIEW sys.dump_comments AS\n"
1087 : " SELECT 'COMMENT ON ' || c.tpe || ' ' || c.fqn || ' IS ' || sys.SQ(c.rem) || ';' stmt FROM sys.describe_comments c;\n"
1088 : "CREATE VIEW sys.dump_user_defined_types AS\n"
1089 : " SELECT 'CREATE TYPE ' || sys.FQN(sch, sql_tpe) || ' EXTERNAL NAME ' || sys.DQ(ext_tpe) || ';' stmt,\n"
1090 : " sch schema_name,\n"
1091 : " sql_tpe type_name\n"
1092 : " FROM sys.describe_user_defined_types;\n"
1093 : "CREATE FUNCTION sys.esc(s STRING) RETURNS STRING BEGIN RETURN '\"' || sys.replace(sys.replace(sys.replace(s,E'\\\\', E'\\\\\\\\'), E'\\n', E'\\\\n'), '\"', E'\\\\\"') || '\"'; END;\n"
1094 : "CREATE FUNCTION sys.prepare_esc(s STRING, t STRING) RETURNS STRING\n"
1095 : "BEGIN\n"
1096 : " RETURN\n"
1097 : " CASE\n"
1098 : " WHEN (t = 'varchar' OR t ='char' OR t = 'clob' OR t = 'json' OR t = 'geometry' OR t = 'url') THEN\n"
1099 : " 'CASE WHEN ' || sys.DQ(s) || ' IS NULL THEN ''null'' ELSE ' || 'sys.esc(' || sys.DQ(s) || ')' || ' END'\n"
1100 : " ELSE\n"
1101 : " 'CASE WHEN ' || sys.DQ(s) || ' IS NULL THEN ''null'' ELSE CAST(' || sys.DQ(s) || ' AS STRING) END'\n"
1102 : " END;\n"
1103 : "END;\n"
1104 : "CREATE PROCEDURE sys.dump_table_data(sch STRING, tbl STRING)\n"
1105 : "BEGIN\n"
1106 : " DECLARE k INT;\n"
1107 : " SET k = (SELECT MIN(c.id) FROM sys.columns c, sys.tables t, sys.schemas s WHERE c.table_id = t.id AND t.name = tbl AND t.schema_id = s.id AND s.name = sch);\n"
1108 : " IF k IS NOT NULL THEN\n"
1109 : " DECLARE cname STRING;\n"
1110 : " DECLARE ctype STRING;\n"
1111 : " SET cname = (SELECT c.name FROM sys.columns c WHERE c.id = k);\n"
1112 : " SET ctype = (SELECT c.type FROM sys.columns c WHERE c.id = k);\n"
1113 : " DECLARE COPY_INTO_STMT STRING;\n"
1114 : " DECLARE _cnt INT;\n"
1115 : " SET _cnt = (SELECT count FROM sys.storage(sch, tbl, cname));\n"
1116 : " IF _cnt > 0 THEN\n"
1117 : " SET COPY_INTO_STMT = 'COPY ' || _cnt || ' RECORDS INTO ' || sys.FQN(sch, tbl) || '(' || sys.DQ(cname);\n"
1118 : " DECLARE SELECT_DATA_STMT STRING;\n"
1119 : " SET SELECT_DATA_STMT = 'SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), ' || sys.prepare_esc(cname, ctype);\n"
1120 : " DECLARE M INT;\n"
1121 : " SET M = (SELECT MAX(c.id) FROM sys.columns c, sys.tables t WHERE c.table_id = t.id AND t.name = tbl);\n"
1122 : " WHILE (k < M) DO\n"
1123 : " SET k = (SELECT MIN(c.id) FROM sys.columns c, sys.tables t WHERE c.table_id = t.id AND t.name = tbl AND c.id > k);\n"
1124 : " SET cname = (SELECT c.name FROM sys.columns c WHERE c.id = k);\n"
1125 : " SET ctype = (SELECT c.type FROM sys.columns c WHERE c.id = k);\n"
1126 : " SET COPY_INTO_STMT = (COPY_INTO_STMT || ', ' || sys.DQ(cname));\n"
1127 : " SET SELECT_DATA_STMT = SELECT_DATA_STMT || '|| ''|'' || ' || sys.prepare_esc(cname, ctype);\n"
1128 : " END WHILE;\n"
1129 : " SET COPY_INTO_STMT = (COPY_INTO_STMT || ') FROM STDIN USING DELIMITERS ''|'',E''\\\\n'',''\"'';');\n"
1130 : " SET SELECT_DATA_STMT = SELECT_DATA_STMT || ' FROM ' || sys.FQN(sch, tbl);\n"
1131 : " insert into sys.dump_statements VALUES ((SELECT COUNT(*) FROM sys.dump_statements) + 1, COPY_INTO_STMT);\n"
1132 : " CALL sys.EVAL('INSERT INTO sys.dump_statements ' || SELECT_DATA_STMT || ';');\n"
1133 : " END IF;\n"
1134 : " END IF;\n"
1135 : "END;\n"
1136 : "CREATE PROCEDURE sys.dump_table_data()\n"
1137 : "BEGIN\n"
1138 : " DECLARE i INT;\n"
1139 : " SET i = (SELECT MIN(t.id) FROM sys.tables t, sys.table_types ts WHERE t.type = ts.table_type_id AND ts.table_type_name = 'TABLE' AND NOT t.system);\n"
1140 : " IF i IS NOT NULL THEN\n"
1141 : " DECLARE M INT;\n"
1142 : " SET M = (SELECT MAX(t.id) FROM sys.tables t, sys.table_types ts WHERE t.type = ts.table_type_id AND ts.table_type_name = 'TABLE' AND NOT t.system);\n"
1143 : " DECLARE sch STRING;\n"
1144 : " DECLARE tbl STRING;\n"
1145 : " WHILE i < M DO\n"
1146 : " set sch = (SELECT s.name FROM sys.tables t, sys.schemas s WHERE s.id = t.schema_id AND t.id = i);\n"
1147 : " set tbl = (SELECT t.name FROM sys.tables t, sys.schemas s WHERE s.id = t.schema_id AND t.id = i);\n"
1148 : " CALL sys.dump_table_data(sch, tbl);\n"
1149 : " SET i = (SELECT MIN(t.id) FROM sys.tables t, sys.table_types ts WHERE t.type = ts.table_type_id AND ts.table_type_name = 'TABLE' AND NOT t.system AND t.id > i);\n"
1150 : " END WHILE;\n"
1151 : " set sch = (SELECT s.name FROM sys.tables t, sys.schemas s WHERE s.id = t.schema_id AND t.id = i);\n"
1152 : " set tbl = (SELECT t.name FROM sys.tables t, sys.schemas s WHERE s.id = t.schema_id AND t.id = i);\n"
1153 : " CALL sys.dump_table_data(sch, tbl);\n"
1154 : " END IF;\n"
1155 : "END;\n"
1156 : "CREATE FUNCTION sys.dump_database(describe BOOLEAN) RETURNS TABLE(o int, stmt STRING)\n"
1157 : "BEGIN\n"
1158 : " SET SCHEMA sys;\n"
1159 : " TRUNCATE sys.dump_statements;\n"
1160 : " INSERT INTO sys.dump_statements VALUES (1, 'START TRANSACTION;');\n"
1161 : " INSERT INTO sys.dump_statements VALUES ((SELECT COUNT(*) FROM sys.dump_statements) + 1, 'SET SCHEMA \"sys\";');\n"
1162 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_roles;\n"
1163 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_users;\n"
1164 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_schemas;\n"
1165 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_user_defined_types;\n"
1166 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_add_schemas_to_users;\n"
1167 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_grant_user_privileges;\n"
1168 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_sequences;\n"
1169 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(ORDER BY stmts.o), stmts.s\n"
1170 : " FROM (\n"
1171 : " SELECT f.o, f.stmt FROM sys.dump_functions f\n"
1172 : " UNION\n"
1173 : " SELECT t.o, t.stmt FROM sys.dump_tables t\n"
1174 : " ) AS stmts(o, s);\n"
1175 : " IF NOT DESCRIBE THEN\n"
1176 : " CALL sys.dump_table_data();\n"
1177 : " END IF;\n"
1178 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_start_sequences;\n"
1179 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_defaults;\n"
1180 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_constraint_type;\n"
1181 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_indices;\n"
1182 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_foreign_keys;\n"
1183 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_partition_tables;\n"
1184 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_triggers;\n"
1185 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_comments;\n"
1186 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_grants;\n"
1187 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_grants;\n"
1188 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_function_grants;\n"
1189 : " INSERT INTO sys.dump_statements VALUES ((SELECT COUNT(*) FROM sys.dump_statements) + 1, 'COMMIT;');\n"
1190 : " RETURN sys.dump_statements;\n"
1191 : "END;\n");
1192 0 : pos += snprintf(buf + pos, bufsize - pos,
1193 : "update sys.functions set system = true where system <> true and name in ('esc', 'prepare_esc') and schema_id = 2000 and type = %d;\n", F_FUNC);
1194 0 : pos += snprintf(buf + pos, bufsize - pos,
1195 : "update sys.functions set system = true where system <> true and name in ('dump_database') and schema_id = 2000 and type = %d;\n", F_UNION);
1196 0 : pos += snprintf(buf + pos, bufsize - pos,
1197 : "update sys.functions set system = true where system <> true and name in ('dump_table_data') and schema_id = 2000 and type = %d;\n", F_PROC);
1198 0 : pos += snprintf(buf + pos, bufsize - pos,
1199 : "update sys._tables set system = true where name in ('dump_create_roles', 'dump_create_users', 'dump_create_schemas', 'dump_add_schemas_to_users', 'dump_grant_user_privileges', 'dump_table_constraint_type', 'dump_table_grants', 'dump_column_grants', 'dump_function_grants', 'dump_indices', 'dump_column_defaults', 'dump_foreign_keys', 'dump_partition_tables', 'dump_sequences', 'dump_start_sequences', 'dump_functions', 'dump_tables', 'dump_triggers', 'dump_comments', 'dump_user_defined_types') AND schema_id = 2000;\n");
1200 :
1201 : /* 80_udf.sql (removed) */
1202 0 : pos += snprintf(buf + pos, bufsize - pos,
1203 : "drop function sys.reverse(string) cascade;\n"
1204 : "drop all function sys.fuse cascade;\n");
1205 :
1206 : /* 26_sysmon.sql */
1207 0 : pos += snprintf(buf + pos, bufsize - pos,
1208 : "create procedure sys.vacuum(sname string, tname string, cname string)\n"
1209 : " external name sql.vacuum;\n"
1210 : "create procedure sys.vacuum(sname string, tname string, cname string, interval int)\n"
1211 : " external name sql.vacuum;\n"
1212 : "create procedure sys.stop_vacuum(sname string, tname string, cname string)\n"
1213 : " external name sql.stop_vacuum;\n");
1214 0 : pos += snprintf(buf + pos, bufsize - pos,
1215 : "update sys.functions set system = true where system <> true and name in ('vacuum', 'stop_vacuum') and schema_id = 2000 and type = %d;\n", F_PROC);
1216 :
1217 : /* 10_sys_schema_extension.sql */
1218 0 : pos += snprintf(buf + pos, bufsize - pos,
1219 : "CREATE TABLE sys.fkey_actions (\n"
1220 : " action_id SMALLINT NOT NULL PRIMARY KEY,\n"
1221 : " action_name VARCHAR(15) NOT NULL);\n"
1222 : "INSERT INTO sys.fkey_actions (action_id, action_name) VALUES\n"
1223 : " (0, 'NO ACTION'),\n"
1224 : " (1, 'CASCADE'),\n"
1225 : " (2, 'RESTRICT'),\n"
1226 : " (3, 'SET NULL'),\n"
1227 : " (4, 'SET DEFAULT');\n"
1228 : "ALTER TABLE sys.fkey_actions SET READ ONLY;\n"
1229 : "GRANT SELECT ON sys.fkey_actions TO PUBLIC;\n"
1230 : "CREATE VIEW sys.fkeys AS\n"
1231 : "SELECT id, table_id, type, name, rkey, update_action_id, upd.action_name as update_action, delete_action_id, del.action_name as delete_action FROM (\n"
1232 : " SELECT id, table_id, type, name, rkey, cast(((\"action\" >> 8) & 255) as smallint) as update_action_id, cast((\"action\" & 255) as smallint) AS delete_action_id FROM sys.keys WHERE type = 2\n"
1233 : " UNION ALL\n"
1234 : " SELECT id, table_id, type, name, rkey, cast(((\"action\" >> 8) & 255) as smallint) as update_action_id, cast((\"action\" & 255) as smallint) AS delete_action_id FROM tmp.keys WHERE type = 2\n"
1235 : ") AS fks\n"
1236 : "JOIN sys.fkey_actions upd ON fks.update_action_id = upd.action_id\n"
1237 : "JOIN sys.fkey_actions del ON fks.delete_action_id = del.action_id;\n"
1238 : "GRANT SELECT ON sys.fkeys TO PUBLIC;\n"
1239 : );
1240 0 : pos += snprintf(buf + pos, bufsize - pos,
1241 : "update sys._tables set system = true where name in ('fkey_actions', 'fkeys') AND schema_id = 2000;\n");
1242 :
1243 : /* recreate SQL functions that just need to be recompiled since the
1244 : * MAL functions's "unsafe" property was changed */
1245 0 : sql_schema *lg = mvc_bind_schema(sql, "logging");
1246 0 : t = mvc_bind_table(sql, lg, "compinfo");
1247 0 : t->system = 0;
1248 0 : t = mvc_bind_table(sql, s, "schemastorage");
1249 0 : t->system = 0;
1250 0 : t = mvc_bind_table(sql, s, "tablestorage");
1251 0 : t->system = 0;
1252 0 : t = mvc_bind_table(sql, s, "storage");
1253 0 : t->system = 0;
1254 0 : t = mvc_bind_table(sql, s, "rejects");
1255 0 : t->system = 0;
1256 0 : t = mvc_bind_table(sql, s, "queue");
1257 0 : t->system = 0;
1258 0 : t = mvc_bind_table(sql, s, "optimizers");
1259 0 : t->system = 0;
1260 0 : t = mvc_bind_table(sql, s, "prepared_statements_args");
1261 0 : t->system = 0;
1262 0 : t = mvc_bind_table(sql, s, "prepared_statements");
1263 0 : t->system = 0;
1264 0 : t = mvc_bind_table(sql, s, "sessions");
1265 0 : t->system = 0;
1266 0 : t = mvc_bind_table(sql, s, "querylog_calls");
1267 0 : t->system = 0;
1268 0 : t = mvc_bind_table(sql, s, "querylog_history");
1269 0 : t->system = 0;
1270 0 : t = mvc_bind_table(sql, s, "querylog_catalog");
1271 0 : t->system = 0;
1272 0 : pos += snprintf(buf + pos, bufsize - pos,
1273 : "drop view logging.compinfo cascade;\n"
1274 : "drop function logging.compinfo cascade;\n"
1275 : "drop procedure sys.storagemodelinit() cascade;\n"
1276 : "drop view sys.schemastorage cascade;\n"
1277 : "drop view sys.tablestorage cascade;\n"
1278 : "drop view sys.storage cascade;\n"
1279 : "drop function sys.storage() cascade;\n"
1280 : "drop function if exists wlr.tick cascade;\n"
1281 : "drop function if exists wlr.clock cascade;\n"
1282 : "drop function if exists wlc.tick cascade;\n"
1283 : "drop function if exists wlc.clock cascade;\n"
1284 : "drop function profiler.getlimit cascade;\n"
1285 : "drop view sys.rejects cascade;\n"
1286 : "drop function sys.rejects cascade;\n"
1287 : "drop function sys.user_statistics cascade;\n"
1288 : "drop view sys.queue cascade;\n"
1289 : "drop function sys.queue cascade;\n"
1290 : "drop function sys.debugflags cascade;\n"
1291 : "drop function sys.bbp cascade;\n"
1292 : "drop view sys.optimizers cascade;\n"
1293 : "drop function sys.optimizers cascade;\n"
1294 : "drop function sys.querycache cascade;\n"
1295 : "drop function sys.optimizer_stats cascade;\n"
1296 : "drop function sys.current_sessionid cascade;\n"
1297 : "drop view sys.prepared_statements_args cascade;\n"
1298 : "drop function sys.prepared_statements_args cascade;\n"
1299 : "drop view sys.prepared_statements cascade;\n"
1300 : "drop function sys.prepared_statements cascade;\n"
1301 : "drop view sys.sessions cascade;\n"
1302 : "drop function sys.sessions cascade;\n"
1303 : "drop view sys.querylog_history cascade;\n"
1304 : "drop view sys.querylog_calls cascade;\n"
1305 : "drop function sys.querylog_calls cascade;\n"
1306 : "drop view sys.querylog_catalog cascade;\n"
1307 : "drop function sys.querylog_catalog cascade;\n"
1308 : "create function sys.querylog_catalog()\n"
1309 : "returns table(\n"
1310 : " id oid,\n"
1311 : " owner string,\n"
1312 : " defined timestamp,\n"
1313 : " query string,\n"
1314 : " pipe string,\n"
1315 : " \"plan\" string,\n"
1316 : " mal int,\n"
1317 : " optimize bigint\n"
1318 : ")\n"
1319 : "external name sql.querylog_catalog;\n"
1320 : "create view sys.querylog_catalog as select * from sys.querylog_catalog();\n"
1321 : "create function sys.querylog_calls()\n"
1322 : "returns table(\n"
1323 : " id oid,\n"
1324 : " \"start\" timestamp,\n"
1325 : " \"stop\" timestamp,\n"
1326 : " arguments string,\n"
1327 : " tuples bigint,\n"
1328 : " run bigint,\n"
1329 : " ship bigint,\n"
1330 : " cpu int,\n"
1331 : " io int\n"
1332 : ")\n"
1333 : "external name sql.querylog_calls;\n"
1334 : "create view sys.querylog_calls as select * from sys.querylog_calls();\n"
1335 : "create view sys.querylog_history as\n"
1336 : "select qd.*, ql.\"start\",ql.\"stop\", ql.arguments, ql.tuples, ql.run, ql.ship, ql.cpu, ql.io\n"
1337 : "from sys.querylog_catalog() qd, sys.querylog_calls() ql\n"
1338 : "where qd.id = ql.id and qd.owner = user;\n"
1339 : "create function sys.sessions()\n"
1340 : " returns table(\n"
1341 : " \"sessionid\" int,\n"
1342 : " \"username\" string,\n"
1343 : " \"login\" timestamp,\n"
1344 : " \"idle\" timestamp,\n"
1345 : " \"optimizer\" string,\n"
1346 : " \"sessiontimeout\" int,\n"
1347 : " \"querytimeout\" int,\n"
1348 : " \"workerlimit\" int,\n"
1349 : " \"memorylimit\" int,\n"
1350 : " \"language\" string,\n"
1351 : " \"peer\" string,\n"
1352 : " \"hostname\" string,\n"
1353 : " \"application\" string,\n"
1354 : " \"client\" string,\n"
1355 : " \"clientpid\" bigint,\n"
1356 : " \"remark\" string\n"
1357 : " )\n"
1358 : " external name sql.sessions;\n"
1359 : "create view sys.sessions as select * from sys.sessions();\n"
1360 : "create function sys.prepared_statements()\n"
1361 : "returns table(\n"
1362 : " \"sessionid\" int,\n"
1363 : " \"username\" string,\n"
1364 : " \"statementid\" int,\n"
1365 : " \"statement\" string,\n"
1366 : " \"created\" timestamp\n"
1367 : ")\n"
1368 : "external name sql.prepared_statements;\n"
1369 : "grant execute on function sys.prepared_statements to public;\n"
1370 : "create view sys.prepared_statements as select * from sys.prepared_statements();\n"
1371 : "grant select on sys.prepared_statements to public;\n"
1372 : "create function sys.prepared_statements_args()\n"
1373 : "returns table(\n"
1374 : " \"statementid\" int,\n"
1375 : " \"type\" string,\n"
1376 : " \"type_digits\" int,\n"
1377 : " \"type_scale\" int,\n"
1378 : " \"inout\" tinyint,\n"
1379 : " \"number\" int,\n"
1380 : " \"schema\" string,\n"
1381 : " \"table\" string,\n"
1382 : " \"column\" string\n"
1383 : ")\n"
1384 : "external name sql.prepared_statements_args;\n"
1385 : "grant execute on function sys.prepared_statements_args to public;\n"
1386 : "create view sys.prepared_statements_args as select * from sys.prepared_statements_args();\n"
1387 : "grant select on sys.prepared_statements_args to public;\n"
1388 : "create function sys.current_sessionid() returns int\n"
1389 : "external name clients.current_sessionid;\n"
1390 : "grant execute on function sys.current_sessionid to public;\n"
1391 : "create function sys.optimizer_stats()\n"
1392 : " returns table (optname string, count int, timing bigint)\n"
1393 : " external name inspect.optimizer_stats;\n"
1394 : "create function sys.querycache()\n"
1395 : " returns table (query string, count int)\n"
1396 : " external name sql.dump_cache;\n"
1397 : "create function sys.optimizers ()\n"
1398 : " returns table (name string, def string, status string)\n"
1399 : " external name sql.optimizers;\n"
1400 : "create view sys.optimizers as select * from sys.optimizers();\n"
1401 : "create function sys.bbp ()\n"
1402 : " returns table (id int, name string,\n"
1403 : " ttype string, count bigint, refcnt int, lrefcnt int,\n"
1404 : " location string, heat int, dirty string,\n"
1405 : " status string, kind string)\n"
1406 : " external name bbp.get;\n"
1407 : "create function sys.debugflags()\n"
1408 : " returns table(flag string, val bool)\n"
1409 : " external name mdb.\"getDebugFlags\";\n"
1410 : "create function sys.queue()\n"
1411 : "returns table(\n"
1412 : " \"tag\" bigint,\n"
1413 : " \"sessionid\" int,\n"
1414 : " \"username\" string,\n"
1415 : " \"started\" timestamp,\n"
1416 : " \"status\" string,\n"
1417 : " \"query\" string,\n"
1418 : " \"finished\" timestamp,\n"
1419 : " \"maxworkers\" int,\n"
1420 : " \"footprint\" int\n"
1421 : ")\n"
1422 : "external name sysmon.queue;\n"
1423 : "grant execute on function sys.queue to public;\n"
1424 : "create view sys.queue as select * from sys.queue();\n"
1425 : "grant select on sys.queue to public;\n"
1426 : "create function sys.user_statistics()\n"
1427 : "returns table(\n"
1428 : " username string,\n"
1429 : " querycount bigint,\n"
1430 : " totalticks bigint,\n"
1431 : " started timestamp,\n"
1432 : " finished timestamp,\n"
1433 : " maxticks bigint,\n"
1434 : " maxquery string\n"
1435 : ")\n"
1436 : "external name sysmon.user_statistics;\n"
1437 : "create function sys.rejects()\n"
1438 : "returns table(\n"
1439 : " rowid bigint,\n"
1440 : " fldid int,\n"
1441 : " \"message\" string,\n"
1442 : " \"input\" string\n"
1443 : ")\n"
1444 : "external name sql.copy_rejects;\n"
1445 : "grant execute on function rejects to public;\n"
1446 : "create view sys.rejects as select * from sys.rejects();\n"
1447 : "create function profiler.getlimit() returns integer external name profiler.getlimit;\n"
1448 : "create function sys.\"storage\"()\n"
1449 : "returns table (\n"
1450 : " \"schema\" varchar(1024),\n"
1451 : " \"table\" varchar(1024),\n"
1452 : " \"column\" varchar(1024),\n"
1453 : " \"type\" varchar(1024),\n"
1454 : " \"mode\" varchar(15),\n"
1455 : " location varchar(1024),\n"
1456 : " \"count\" bigint,\n"
1457 : " typewidth int,\n"
1458 : " columnsize bigint,\n"
1459 : " heapsize bigint,\n"
1460 : " hashes bigint,\n"
1461 : " phash boolean,\n"
1462 : " \"imprints\" bigint,\n"
1463 : " sorted boolean,\n"
1464 : " revsorted boolean,\n"
1465 : " \"unique\" boolean,\n"
1466 : " orderidx bigint\n"
1467 : ")\n"
1468 : "external name sql.\"storage\";\n"
1469 : "create view sys.\"storage\" as\n"
1470 : "select * from sys.\"storage\"()\n"
1471 : " where (\"schema\", \"table\") in (\n"
1472 : " select sch.\"name\", tbl.\"name\"\n"
1473 : " from sys.\"tables\" as tbl join sys.\"schemas\" as sch on tbl.schema_id = sch.id\n"
1474 : " where tbl.\"system\" = false)\n"
1475 : "order by \"schema\", \"table\", \"column\";\n"
1476 : "create view sys.\"tablestorage\" as\n"
1477 : "select \"schema\", \"table\",\n"
1478 : " max(\"count\") as \"rowcount\",\n"
1479 : " count(*) as \"storages\",\n"
1480 : " sum(columnsize) as columnsize,\n"
1481 : " sum(heapsize) as heapsize,\n"
1482 : " sum(hashes) as hashsize,\n"
1483 : " sum(\"imprints\") as imprintsize,\n"
1484 : " sum(orderidx) as orderidxsize\n"
1485 : " from sys.\"storage\"\n"
1486 : "group by \"schema\", \"table\"\n"
1487 : "order by \"schema\", \"table\";\n"
1488 : "create view sys.\"schemastorage\" as\n"
1489 : "select \"schema\",\n"
1490 : " count(*) as \"storages\",\n"
1491 : " sum(columnsize) as columnsize,\n"
1492 : " sum(heapsize) as heapsize,\n"
1493 : " sum(hashes) as hashsize,\n"
1494 : " sum(\"imprints\") as imprintsize,\n"
1495 : " sum(orderidx) as orderidxsize\n"
1496 : " from sys.\"storage\"\n"
1497 : "group by \"schema\"\n"
1498 : "order by \"schema\";\n"
1499 : "create procedure sys.storagemodelinit()\n"
1500 : "begin\n"
1501 : " delete from sys.storagemodelinput;\n"
1502 : " insert into sys.storagemodelinput\n"
1503 : " select \"schema\", \"table\", \"column\", \"type\", typewidth, \"count\",\n"
1504 : " case when (\"unique\" or \"type\" in ('varchar', 'char', 'clob', 'json', 'url', 'blob', 'geometry', 'geometrya'))\n"
1505 : " then \"count\" else 0 end,\n"
1506 : " case when \"count\" > 0 and heapsize >= 8192 and \"type\" in ('varchar', 'char', 'clob', 'json', 'url')\n"
1507 : " then cast((heapsize - 8192) / \"count\" as bigint)\n"
1508 : " when \"count\" > 0 and heapsize >= 32 and \"type\" in ('blob', 'geometry', 'geometrya')\n"
1509 : " then cast((heapsize - 32) / \"count\" as bigint)\n"
1510 : " else typewidth end,\n"
1511 : " false, case sorted when true then true else false end, \"unique\", true\n"
1512 : " from sys.\"storage\";\n"
1513 : " update sys.storagemodelinput\n"
1514 : " set reference = true\n"
1515 : " where (\"schema\", \"table\", \"column\") in (\n"
1516 : " select fkschema.\"name\", fktable.\"name\", fkkeycol.\"name\"\n"
1517 : " from sys.\"keys\" as fkkey,\n"
1518 : " sys.\"objects\" as fkkeycol,\n"
1519 : " sys.\"tables\" as fktable,\n"
1520 : " sys.\"schemas\" as fkschema\n"
1521 : " where fktable.\"id\" = fkkey.\"table_id\"\n"
1522 : " and fkkey.\"id\" = fkkeycol.\"id\"\n"
1523 : " and fkschema.\"id\" = fktable.\"schema_id\"\n"
1524 : " and fkkey.\"rkey\" > -1 );\n"
1525 : " update sys.storagemodelinput\n"
1526 : " set isacolumn = false\n"
1527 : " where (\"schema\", \"table\", \"column\") not in (\n"
1528 : " select sch.\"name\", tbl.\"name\", col.\"name\"\n"
1529 : " from sys.\"schemas\" as sch,\n"
1530 : " sys.\"tables\" as tbl,\n"
1531 : " sys.\"columns\" as col\n"
1532 : " where sch.\"id\" = tbl.\"schema_id\"\n"
1533 : " and tbl.\"id\" = col.\"table_id\");\n"
1534 : "end;\n"
1535 : "create function logging.compinfo()\n"
1536 : "returns table(\n"
1537 : " \"id\" int,\n"
1538 : " \"component\" string,\n"
1539 : " \"log_level\" string\n"
1540 : ")\n"
1541 : "external name logging.compinfo;\n"
1542 : "grant execute on function logging.compinfo to public;\n"
1543 : "create view logging.compinfo as select * from logging.compinfo();\n"
1544 : "grant select on logging.compinfo to public;\n"
1545 : "update sys._tables set system = true where system <> true and schema_id = 2000 and name in ('schemastorage', 'tablestorage', 'storage', 'rejects', 'queue', 'optimizers', 'prepared_statements_args', 'prepared_statements', 'sessions', 'querylog_history', 'querylog_calls', 'querylog_catalog');\n"
1546 : "update sys._tables set system = true where system <> true and schema_id = (select id from sys.schemas where name = 'logging') and name = 'compinfo';\n"
1547 : "update sys.functions set system = true where system <> true and schema_id = 2000 and name in ('storagemodelinit', 'storage', 'rejects', 'user_statistics', 'queue', 'debugflags', 'bbp', 'optimizers', 'querycache', 'optimizer_stats', 'current_sessionid', 'prepared_statements_args', 'prepared_statements', 'sessions', 'querylog_calls', 'querylog_catalog');\n"
1548 : "update sys.functions set system = true where system <> true and schema_id = (select id from sys.schemas where name = 'logging') and name = 'compinfo';\n"
1549 : "update sys.functions set system = true where system <> true and schema_id = (select id from sys.schemas where name = 'profiler') and name = 'getlimit';\n"
1550 : );
1551 :
1552 : /* 99_system.sql */
1553 0 : t = mvc_bind_table(sql, s, "systemfunctions");
1554 0 : t->system = 0;
1555 0 : pos += snprintf(buf + pos, bufsize - pos,
1556 : "drop view sys.systemfunctions cascade;\n");
1557 :
1558 : /* 80_statistics.sql */
1559 0 : t = mvc_bind_table(sql, s, "statistics");
1560 0 : t->system = 0;
1561 0 : pos += snprintf(buf + pos, bufsize - pos,
1562 : "drop table sys.statistics cascade;\n"
1563 : "drop procedure sys.analyze(int,bigint) cascade;\n"
1564 : "drop procedure sys.analyze(int,bigint,string) cascade;\n"
1565 : "drop procedure sys.analyze(int,bigint,string,string) cascade;\n"
1566 : "drop procedure sys.analyze(int,bigint,string,string,string) cascade;\n"
1567 : "create procedure sys.\"analyze\"()\n"
1568 : "external name sql.\"analyze\";\n"
1569 : "grant execute on procedure sys.\"analyze\"() to public;\n"
1570 : "create procedure sys.\"analyze\"(\"sname\" varchar(1024))\n"
1571 : "external name sql.\"analyze\";\n"
1572 : "grant execute on procedure sys.\"analyze\"(varchar(1024)) to public;\n"
1573 : "create procedure sys.\"analyze\"(\"sname\" varchar(1024), \"tname\" varchar(1024))\n"
1574 : "external name sql.\"analyze\";\n"
1575 : "grant execute on procedure sys.\"analyze\"(varchar(1024),varchar(1024)) to public;\n"
1576 : "create procedure sys.\"analyze\"(\"sname\" varchar(1024), \"tname\" varchar(1024), \"cname\" varchar(1024))\n"
1577 : "external name sql.\"analyze\";\n"
1578 : "grant execute on procedure sys.\"analyze\"(varchar(1024),varchar(1024),varchar(1024)) to public;\n"
1579 : "create function sys.\"statistics\"()\n"
1580 : "returns table (\n"
1581 : " \"column_id\" integer,\n"
1582 : " \"schema\" varchar(1024),\n"
1583 : " \"table\" varchar(1024),\n"
1584 : " \"column\" varchar(1024),\n"
1585 : " \"type\" varchar(1024),\n"
1586 : " \"width\" integer,\n"
1587 : " \"count\" bigint,\n"
1588 : " \"unique\" boolean,\n"
1589 : " \"nils\" boolean,\n"
1590 : " \"minval\" string,\n"
1591 : " \"maxval\" string,\n"
1592 : " \"sorted\" boolean,\n"
1593 : " \"revsorted\" boolean\n"
1594 : ")\n"
1595 : "external name sql.\"statistics\";\n"
1596 : "grant execute on function sys.\"statistics\"() to public;\n"
1597 : "create view sys.\"statistics\" as\n"
1598 : "select * from sys.\"statistics\"()\n"
1599 : "-- exclude system tables\n"
1600 : "where (\"schema\", \"table\") in (\n"
1601 : " SELECT sch.\"name\", tbl.\"name\"\n"
1602 : " FROM sys.\"tables\" AS tbl JOIN sys.\"schemas\" AS sch ON tbl.schema_id = sch.id\n"
1603 : " WHERE tbl.\"system\" = FALSE)\n"
1604 : "order by \"schema\", \"table\", \"column\";\n"
1605 : "grant select on sys.\"statistics\" to public;\n"
1606 : "create function sys.\"statistics\"(\"sname\" varchar(1024))\n"
1607 : "returns table (\n"
1608 : " \"column_id\" integer,\n"
1609 : " \"schema\" varchar(1024),\n"
1610 : " \"table\" varchar(1024),\n"
1611 : " \"column\" varchar(1024),\n"
1612 : " \"type\" varchar(1024),\n"
1613 : " \"width\" integer,\n"
1614 : " \"count\" bigint,\n"
1615 : " \"unique\" boolean,\n"
1616 : " \"nils\" boolean,\n"
1617 : " \"minval\" string,\n"
1618 : " \"maxval\" string,\n"
1619 : " \"sorted\" boolean,\n"
1620 : " \"revsorted\" boolean\n"
1621 : ")\n"
1622 : "external name sql.\"statistics\";\n"
1623 : "grant execute on function sys.\"statistics\"(varchar(1024)) to public;\n"
1624 : "create function sys.\"statistics\"(\"sname\" varchar(1024), \"tname\" varchar(1024))\n"
1625 : "returns table (\n"
1626 : " \"column_id\" integer,\n"
1627 : " \"schema\" varchar(1024),\n"
1628 : " \"table\" varchar(1024),\n"
1629 : " \"column\" varchar(1024),\n"
1630 : " \"type\" varchar(1024),\n"
1631 : " \"width\" integer,\n"
1632 : " \"count\" bigint,\n"
1633 : " \"unique\" boolean,\n"
1634 : " \"nils\" boolean,\n"
1635 : " \"minval\" string,\n"
1636 : " \"maxval\" string,\n"
1637 : " \"sorted\" boolean,\n"
1638 : " \"revsorted\" boolean\n"
1639 : ")\n"
1640 : "external name sql.\"statistics\";\n"
1641 : "grant execute on function sys.\"statistics\"(varchar(1024),varchar(1024)) to public;\n"
1642 : "create function sys.\"statistics\"(\"sname\" varchar(1024), \"tname\" varchar(1024), \"cname\" varchar(1024))\n"
1643 : "returns table (\n"
1644 : " \"column_id\" integer,\n"
1645 : " \"schema\" varchar(1024),\n"
1646 : " \"table\" varchar(1024),\n"
1647 : " \"column\" varchar(1024),\n"
1648 : " \"type\" varchar(1024),\n"
1649 : " \"width\" integer,\n"
1650 : " \"count\" bigint,\n"
1651 : " \"unique\" boolean,\n"
1652 : " \"nils\" boolean,\n"
1653 : " \"minval\" string,\n"
1654 : " \"maxval\" string,\n"
1655 : " \"sorted\" boolean,\n"
1656 : " \"revsorted\" boolean\n"
1657 : ")\n"
1658 : "external name sql.\"statistics\";\n"
1659 : "grant execute on function sys.\"statistics\"(varchar(1024),varchar(1024),varchar(1024)) to public;\n"
1660 : "update sys._tables set system = true where system <> true and schema_id = 2000 and name = 'statistics';\n"
1661 : "update sys.functions set system = true where system <> true and schema_id = 2000 and name in ('analyze','statistics');\n");
1662 :
1663 0 : assert(pos < bufsize);
1664 0 : printf("Running database upgrade commands:\n%s\n", buf);
1665 0 : fflush(stdout);
1666 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
1667 :
1668 0 : GDKfree(buf);
1669 0 : return err; /* usually MAL_SUCCEED */
1670 : }
1671 :
1672 : static str
1673 96 : sql_update_sep2022(Client c, mvc *sql, sql_schema *s)
1674 : {
1675 96 : size_t bufsize = 65536, pos = 0;
1676 96 : char *err = NULL, *buf = GDKmalloc(bufsize);
1677 96 : res_table *output;
1678 96 : BAT *b;
1679 :
1680 96 : if (buf == NULL)
1681 0 : throw(SQL, __func__, SQLSTATE(HY013) MAL_MALLOC_FAIL);
1682 :
1683 : /* if sys.db_user_info does not have a column password, we need to
1684 : * add a bunch of columns */
1685 96 : sql_table *db_user_info = find_sql_table(sql->session->tr, s, "db_user_info");
1686 96 : if (find_sql_column(db_user_info, "password") == NULL) {
1687 0 : pos += snprintf(buf + pos, bufsize - pos,
1688 : "alter table sys.db_user_info add column max_memory bigint;\n"
1689 : "alter table sys.db_user_info add column max_workers int;\n"
1690 : "alter table sys.db_user_info add column optimizer varchar(1024);\n"
1691 : "alter table sys.db_user_info add column default_role int;\n"
1692 : "alter table sys.db_user_info add column password varchar(256);\n");
1693 0 : pos += snprintf(buf + pos, bufsize - pos,
1694 : "update sys.db_user_info u set max_memory = 0, max_workers = 0, optimizer = 'default_pipe', default_role = (select id from sys.auths a where a.name = u.name);\n");
1695 0 : int endprint = (int) pos;
1696 0 : bat bid;
1697 0 : BAT *u = NULL, *p = NULL, *d = NULL;
1698 0 : if ((bid = BBPindex("M5system_auth_user")) == 0 ||
1699 0 : (u = BATdescriptor(bid)) == NULL ||
1700 0 : (bid = BBPindex("M5system_auth_passwd_v2")) == 0 ||
1701 0 : (p = BATdescriptor(bid)) == NULL ||
1702 0 : (bid = BBPindex("M5system_auth_deleted")) == 0 ||
1703 0 : (d = BATdescriptor(bid)) == NULL) {
1704 0 : BBPreclaim(u);
1705 0 : BBPreclaim(p);
1706 0 : BBPreclaim(d);
1707 0 : throw(SQL, __func__, INTERNAL_BAT_ACCESS);
1708 : }
1709 0 : BATiter ui = bat_iterator(u);
1710 0 : BATiter pi = bat_iterator(p);
1711 0 : for (oid i = 0; i < ui.count; i++) {
1712 0 : if (BUNfnd(d, &i) == BUN_NONE) {
1713 0 : const char *user = BUNtvar(ui, i);
1714 0 : const char *pass = BUNtvar(pi, i);
1715 0 : if (pos + 4 * (strlen(user) + strlen(pass)) + 64 >= bufsize) {
1716 0 : char *nbuf = GDKrealloc(buf, bufsize + 65536);
1717 0 : if (nbuf == NULL) {
1718 0 : err = createException(SQL, __func__, MAL_MALLOC_FAIL);
1719 0 : break;
1720 : }
1721 : buf = nbuf;
1722 : bufsize += 65536;
1723 : }
1724 0 : pos += snprintf(buf + pos, bufsize - pos,
1725 : "update sys.db_user_info set password = e'");
1726 0 : for (const char *p = pass; *p; p++) {
1727 0 : if (*p < '\040' || *p >= '\177') {
1728 : /* control character or high bit set */
1729 0 : pos += snprintf(buf + pos, bufsize - pos,
1730 : "\\%03o", (unsigned char) *p);
1731 : } else {
1732 0 : if (*p == '\\' || *p == '\'')
1733 0 : buf[pos++] = *p;
1734 0 : buf[pos++] = *p;
1735 : }
1736 : }
1737 0 : pos += snprintf(buf + pos, bufsize - pos,
1738 : "' where name = e'");
1739 0 : for (const char *p = user; *p; p++) {
1740 0 : if (*p < '\040' || *p >= '\177') {
1741 : /* control character or high bit set */
1742 0 : pos += snprintf(buf + pos, bufsize - pos,
1743 : "\\%03o", (unsigned char) *p);
1744 : } else {
1745 0 : if (*p == '\\' || *p == '\'')
1746 0 : buf[pos++] = *p;
1747 0 : buf[pos++] = *p;
1748 : }
1749 : }
1750 0 : pos += snprintf(buf + pos, bufsize - pos,
1751 : "';\n");
1752 : }
1753 : }
1754 0 : if (err == MAL_SUCCEED) {
1755 0 : assert(pos < bufsize);
1756 0 : printf("Running database upgrade commands:\n%.*s-- and copying passwords\n\n", endprint, buf);
1757 0 : fflush(stdout);
1758 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
1759 : }
1760 0 : bat_iterator_end(&ui);
1761 0 : bat_iterator_end(&pi);
1762 0 : bat authbats[4];
1763 0 : authbats[0] = 0;
1764 0 : authbats[1] = u->batCacheid;
1765 0 : authbats[2] = p->batCacheid;
1766 0 : authbats[3] = d->batCacheid;
1767 0 : if (err == MAL_SUCCEED &&
1768 0 : (BATmode(u, true) != GDK_SUCCEED ||
1769 0 : BATmode(p, true) != GDK_SUCCEED ||
1770 0 : BATmode(d, true) != GDK_SUCCEED ||
1771 0 : BBPrename(u, NULL) != 0 ||
1772 0 : BBPrename(p, NULL) != 0 ||
1773 0 : BBPrename(d, NULL) != 0 ||
1774 0 : TMsubcommit_list(authbats, NULL, 4, -1) != GDK_SUCCEED)) {
1775 0 : fprintf(stderr, "Committing removal of old user/password BATs failed\n");
1776 : }
1777 0 : BBPunfix(u->batCacheid);
1778 0 : BBPunfix(p->batCacheid);
1779 0 : BBPunfix(d->batCacheid);
1780 :
1781 0 : if (err == MAL_SUCCEED) {
1782 0 : sql_schema *s = mvc_bind_schema(sql, "sys");
1783 0 : sql_table *t = mvc_bind_table(sql, s, "roles");
1784 0 : t->system = 0;
1785 0 : t = mvc_bind_table(sql, s, "users");
1786 0 : t->system = 0;
1787 0 : t = mvc_bind_table(sql, s, "dependency_schemas_on_users");
1788 0 : t->system = 0;
1789 0 : pos = 0;
1790 0 : pos += snprintf(buf + pos, bufsize - pos,
1791 : "drop view sys.dependency_schemas_on_users cascade;\n"
1792 : "drop view sys.roles cascade;\n"
1793 : "drop view sys.users cascade;\n"
1794 : "drop function sys.db_users() cascade;\n"
1795 : "CREATE VIEW sys.roles AS SELECT id, name, grantor FROM sys.auths a WHERE a.name NOT IN (SELECT u.name FROM sys.db_user_info u);\n"
1796 : "GRANT SELECT ON sys.roles TO PUBLIC;\n"
1797 : "CREATE VIEW sys.users AS SELECT name, fullname, default_schema, schema_path, max_memory, max_workers, optimizer, default_role FROM sys.db_user_info;\n"
1798 : "GRANT SELECT ON sys.users TO PUBLIC;\n"
1799 : "CREATE FUNCTION sys.db_users() RETURNS TABLE(name varchar(2048)) RETURN SELECT name FROM sys.db_user_info;\n"
1800 : "CREATE VIEW sys.dependency_schemas_on_users AS\n"
1801 : "SELECT s.id AS schema_id, s.name AS schema_name, u.name AS user_name, CAST(6 AS smallint) AS depend_type\n"
1802 : " FROM sys.db_user_info AS u, sys.schemas AS s\n"
1803 : " WHERE u.default_schema = s.id\n"
1804 : " ORDER BY s.name, u.name;\n"
1805 : "GRANT SELECT ON sys.dependency_schemas_on_users TO PUBLIC;\n"
1806 : "update sys._tables set system = true where name in ('users', 'roles', 'dependency_schemas_on_users') AND schema_id = 2000;\n"
1807 : "update sys.functions set system = true where system <> true and name in ('db_users') and schema_id = 2000 and type = %d;\n", F_UNION);
1808 0 : assert(pos < bufsize);
1809 0 : printf("Running database upgrade commands:\n%s\n", buf);
1810 0 : fflush(stdout);
1811 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
1812 : }
1813 : }
1814 96 : if (err != MAL_SUCCEED) {
1815 0 : GDKfree(buf);
1816 0 : return err;
1817 : }
1818 :
1819 : /* if 'describe_partition_tables' system view doesn't use 'vals'
1820 : * CTE, re-create it; while we're at it, also update the sequence
1821 : * dumping code */
1822 96 : pos = snprintf(buf, bufsize,
1823 : "select 1 from sys.tables where schema_id = (select \"id\" from sys.schemas where \"name\" = 'sys') and \"name\" = 'describe_partition_tables' and \"query\" not like '%%vals%%';\n");
1824 96 : if ((err = SQLstatementIntern(c, buf, "update", true, false, &output))) {
1825 0 : GDKfree(buf);
1826 0 : return err;
1827 : }
1828 :
1829 96 : if ((b = BBPquickdesc(output->cols[0].b)) && BATcount(b) > 0) {
1830 : /* 52_describe.sql; but we need to drop dependencies from 76_dump.sql first */
1831 0 : sql_schema *s = mvc_bind_schema(sql, "sys");
1832 0 : sql_table *t = mvc_bind_table(sql, s, "describe_partition_tables");
1833 0 : t->system = 0;
1834 0 : t = mvc_bind_table(sql, s, "dump_partition_tables");
1835 0 : t->system = 0;
1836 0 : t = mvc_bind_table(sql, s, "dump_sequences");
1837 0 : t->system = 0;
1838 0 : t = mvc_bind_table(sql, s, "dump_start_sequences");
1839 0 : t->system = 0;
1840 0 : t = mvc_bind_table(sql, s, "describe_tables");
1841 0 : t->system = 0;
1842 0 : t = mvc_bind_table(sql, s, "dump_tables");
1843 0 : t->system = 0;
1844 0 : t = mvc_bind_table(sql, s, "dump_create_users");
1845 0 : t->system = 0;
1846 0 : t = mvc_bind_table(sql, s, "dump_functions");
1847 0 : t->system = 0;
1848 0 : t = mvc_bind_table(sql, s, "dump_triggers");
1849 0 : t->system = 0;
1850 :
1851 0 : pos = 0;
1852 0 : pos += snprintf(buf + pos, bufsize - pos,
1853 : /* drop dependent stuff from 76_dump.sql */
1854 : "drop function sys.dump_database(boolean) cascade;\n"
1855 : "drop procedure sys.dump_table_data() cascade;\n"
1856 : "drop procedure sys.dump_table_data(string, string) cascade;\n"
1857 : "drop view sys.dump_partition_tables cascade;\n"
1858 : "drop view sys.describe_partition_tables cascade;\n"
1859 : "drop view sys.dump_sequences cascade;\n"
1860 : "drop view sys.dump_start_sequences cascade;\n"
1861 : "drop view sys.dump_tables cascade;\n"
1862 : "drop view sys.describe_tables cascade;\n"
1863 : "drop view sys.dump_create_users cascade;\n"
1864 : "drop view sys.dump_functions cascade;\n"
1865 : "drop view sys.dump_triggers cascade;\n"
1866 : "drop function sys.schema_guard cascade;\n"
1867 : "drop function sys.replace_first(string, string, string, string) cascade;\n");
1868 :
1869 0 : pos += snprintf(buf + pos, bufsize - pos,
1870 : "CREATE FUNCTION sys.schema_guard(sch STRING, nme STRING, stmt STRING) RETURNS STRING BEGIN\n"
1871 : "RETURN\n"
1872 : " SELECT 'SET SCHEMA ' || sys.dq(sch) || '; ' || stmt;\n"
1873 : "END;\n"
1874 : "CREATE VIEW sys.dump_functions AS\n"
1875 : " SELECT f.o o, sys.schema_guard(f.sch, f.fun, f.def) stmt,\n"
1876 : " f.sch schema_name,\n"
1877 : " f.fun function_name\n"
1878 : " FROM sys.describe_functions f;\n"
1879 : "CREATE VIEW sys.dump_triggers AS\n"
1880 : " SELECT sys.schema_guard(sch, tab, def) stmt,\n"
1881 : " sch schema_name,\n"
1882 : " tab table_name,\n"
1883 : " tri trigger_name\n"
1884 : " FROM sys.describe_triggers;\n"
1885 : "CREATE VIEW sys.describe_partition_tables AS\n"
1886 : " SELECT\n"
1887 : " m_sch,\n"
1888 : " m_tbl,\n"
1889 : " p_sch,\n"
1890 : " p_tbl,\n"
1891 : " CASE\n"
1892 : " WHEN p_raw_type IS NULL THEN 'READ ONLY'\n"
1893 : " WHEN (p_raw_type = 'VALUES' AND pvalues IS NULL) OR (p_raw_type = 'RANGE' AND minimum IS NULL AND maximum IS NULL AND with_nulls) THEN 'FOR NULLS'\n"
1894 : " ELSE p_raw_type\n"
1895 : " END AS tpe,\n"
1896 : " pvalues,\n"
1897 : " minimum,\n"
1898 : " maximum,\n"
1899 : " with_nulls\n"
1900 : " FROM\n"
1901 : " (WITH\n"
1902 : " tp(\"type\", table_id) AS\n"
1903 : " (SELECT ifthenelse((table_partitions.\"type\" & 2) = 2, 'VALUES', 'RANGE'), table_partitions.table_id FROM sys.table_partitions),\n"
1904 : " subq(m_tid, p_mid, \"type\", m_sch, m_tbl, p_sch, p_tbl) AS\n"
1905 : " (SELECT m_t.id, p_m.id, m_t.\"type\", m_s.name, m_t.name, p_s.name, p_m.name\n"
1906 : " FROM sys.schemas m_s, sys._tables m_t, sys.dependencies d, sys.schemas p_s, sys._tables p_m\n"
1907 : " WHERE m_t.\"type\" IN (3, 6)\n"
1908 : " AND m_t.schema_id = m_s.id\n"
1909 : " AND m_s.name <> 'tmp'\n"
1910 : " AND m_t.system = FALSE\n"
1911 : " AND m_t.id = d.depend_id\n"
1912 : " AND d.id = p_m.id\n"
1913 : " AND p_m.schema_id = p_s.id\n"
1914 : " ORDER BY m_t.id, p_m.id),\n"
1915 : " vals(id,vals) as\n"
1916 : " (SELECT vp.table_id, GROUP_CONCAT(vp.value, ',') FROM sys.value_partitions vp GROUP BY vp.table_id)\n"
1917 : " SELECT\n"
1918 : " subq.m_sch,\n"
1919 : " subq.m_tbl,\n"
1920 : " subq.p_sch,\n"
1921 : " subq.p_tbl,\n"
1922 : " tp.\"type\" AS p_raw_type,\n"
1923 : " CASE WHEN tp.\"type\" = 'VALUES'\n"
1924 : " THEN (SELECT vals.vals FROM vals WHERE vals.id = subq.p_mid)\n"
1925 : " ELSE NULL\n"
1926 : " END AS pvalues,\n"
1927 : " CASE WHEN tp.\"type\" = 'RANGE'\n"
1928 : " THEN (SELECT minimum FROM sys.range_partitions rp WHERE rp.table_id = subq.p_mid)\n"
1929 : " ELSE NULL\n"
1930 : " END AS minimum,\n"
1931 : " CASE WHEN tp.\"type\" = 'RANGE'\n"
1932 : " THEN (SELECT maximum FROM sys.range_partitions rp WHERE rp.table_id = subq.p_mid)\n"
1933 : " ELSE NULL\n"
1934 : " END AS maximum,\n"
1935 : " CASE WHEN tp.\"type\" = 'VALUES'\n"
1936 : " THEN EXISTS(SELECT vp.value FROM sys.value_partitions vp WHERE vp.table_id = subq.p_mid AND vp.value IS NULL)\n"
1937 : " ELSE (SELECT rp.with_nulls FROM sys.range_partitions rp WHERE rp.table_id = subq.p_mid)\n"
1938 : " END AS with_nulls\n"
1939 : " FROM\n"
1940 : " subq LEFT OUTER JOIN tp\n"
1941 : " ON subq.m_tid = tp.table_id) AS tmp_pi;\n"
1942 : "GRANT SELECT ON sys.describe_partition_tables TO PUBLIC;\n"
1943 : "CREATE VIEW sys.dump_partition_tables AS\n"
1944 : "SELECT\n"
1945 : " 'ALTER TABLE ' || sys.FQN(m_sch, m_tbl) || ' ADD TABLE ' || sys.FQN(p_sch, p_tbl) ||\n"
1946 : " CASE\n"
1947 : " WHEN tpe = 'VALUES' THEN ' AS PARTITION IN (' || pvalues || ')'\n"
1948 : " WHEN tpe = 'RANGE' THEN ' AS PARTITION FROM ' || ifthenelse(minimum IS NOT NULL, sys.SQ(minimum), 'RANGE MINVALUE') || ' TO ' || ifthenelse(maximum IS NOT NULL, sys.SQ(maximum), 'RANGE MAXVALUE')\n"
1949 : " WHEN tpe = 'FOR NULLS' THEN ' AS PARTITION FOR NULL VALUES'\n"
1950 : " ELSE '' --'READ ONLY'\n"
1951 : " END ||\n"
1952 : " CASE WHEN tpe in ('VALUES', 'RANGE') AND with_nulls THEN ' WITH NULL VALUES' ELSE '' END ||\n"
1953 : " ';' stmt,\n"
1954 : " m_sch merge_schema_name,\n"
1955 : " m_tbl merge_table_name,\n"
1956 : " p_sch partition_schema_name,\n"
1957 : " p_tbl partition_table_name\n"
1958 : " FROM sys.describe_partition_tables;\n"
1959 : "CREATE VIEW sys.dump_sequences AS\n"
1960 : " SELECT\n"
1961 : " 'CREATE SEQUENCE ' || sys.FQN(sch, seq) || ' AS BIGINT;' stmt,\n"
1962 : " sch schema_name,\n"
1963 : " seq seqname\n"
1964 : " FROM sys.describe_sequences;\n"
1965 : "CREATE VIEW sys.dump_start_sequences AS\n"
1966 : " SELECT 'ALTER SEQUENCE ' || sys.FQN(sch, seq) ||\n"
1967 : " CASE WHEN s = 0 THEN '' ELSE ' RESTART WITH ' || rs END ||\n"
1968 : " CASE WHEN inc = 1 THEN '' ELSE ' INCREMENT BY ' || inc END ||\n"
1969 : " CASE WHEN nomin THEN ' NO MINVALUE' WHEN rmi IS NULL THEN '' ELSE ' MINVALUE ' || rmi END ||\n"
1970 : " CASE WHEN nomax THEN ' NO MAXVALUE' WHEN rma IS NULL THEN '' ELSE ' MAXVALUE ' || rma END ||\n"
1971 : " CASE WHEN \"cache\" = 1 THEN '' ELSE ' CACHE ' || \"cache\" END ||\n"
1972 : " CASE WHEN \"cycle\" THEN '' ELSE ' NO' END || ' CYCLE;' stmt,\n"
1973 : " sch schema_name,\n"
1974 : " seq sequence_name\n"
1975 : " FROM sys.describe_sequences;\n"
1976 : "CREATE PROCEDURE sys.dump_table_data(sch STRING, tbl STRING)\n"
1977 : "BEGIN\n"
1978 : " DECLARE tid INT;\n"
1979 : " SET tid = (SELECT MIN(t.id) FROM sys.tables t, sys.schemas s WHERE t.name = tbl AND t.schema_id = s.id AND s.name = sch);\n"
1980 : " IF tid IS NOT NULL THEN\n"
1981 : " DECLARE k INT;\n"
1982 : " DECLARE m INT;\n"
1983 : " SET k = (SELECT MIN(c.id) FROM sys.columns c WHERE c.table_id = tid);\n"
1984 : " SET m = (SELECT MAX(c.id) FROM sys.columns c WHERE c.table_id = tid);\n"
1985 : " IF k IS NOT NULL AND m IS NOT NULL THEN\n"
1986 : " DECLARE cname STRING;\n"
1987 : " DECLARE ctype STRING;\n"
1988 : " DECLARE _cnt INT;\n"
1989 : " SET cname = (SELECT c.name FROM sys.columns c WHERE c.id = k);\n"
1990 : " SET ctype = (SELECT c.type FROM sys.columns c WHERE c.id = k);\n"
1991 : " SET _cnt = (SELECT count FROM sys.storage(sch, tbl, cname));\n"
1992 : " IF _cnt > 0 THEN\n"
1993 : " DECLARE COPY_INTO_STMT STRING;\n"
1994 : " DECLARE SELECT_DATA_STMT STRING;\n"
1995 : " SET COPY_INTO_STMT = 'COPY ' || _cnt || ' RECORDS INTO ' || sys.FQN(sch, tbl) || '(' || sys.DQ(cname);\n"
1996 : " SET SELECT_DATA_STMT = 'SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), ' || sys.prepare_esc(cname, ctype);\n"
1997 : " WHILE (k < m) DO\n"
1998 : " SET k = (SELECT MIN(c.id) FROM sys.columns c WHERE c.table_id = tid AND c.id > k);\n"
1999 : " SET cname = (SELECT c.name FROM sys.columns c WHERE c.id = k);\n"
2000 : " SET ctype = (SELECT c.type FROM sys.columns c WHERE c.id = k);\n"
2001 : " SET COPY_INTO_STMT = (COPY_INTO_STMT || ', ' || sys.DQ(cname));\n"
2002 : " SET SELECT_DATA_STMT = (SELECT_DATA_STMT || '|| ''|'' || ' || sys.prepare_esc(cname, ctype));\n"
2003 : " END WHILE;\n"
2004 : " SET COPY_INTO_STMT = (COPY_INTO_STMT || ') FROM STDIN USING DELIMITERS ''|'',E''\\\\n'',''\"'';');\n"
2005 : " SET SELECT_DATA_STMT = (SELECT_DATA_STMT || ' FROM ' || sys.FQN(sch, tbl));\n"
2006 : " INSERT INTO sys.dump_statements VALUES ((SELECT COUNT(*) FROM sys.dump_statements) + 1, COPY_INTO_STMT);\n"
2007 : " CALL sys.EVAL('INSERT INTO sys.dump_statements ' || SELECT_DATA_STMT || ';');\n"
2008 : " END IF;\n"
2009 : " END IF;\n"
2010 : " END IF;\n"
2011 : "END;\n"
2012 : "CREATE PROCEDURE sys.dump_table_data()\n"
2013 : "BEGIN\n"
2014 : " DECLARE i INT;\n"
2015 : " SET i = (SELECT MIN(t.id) FROM sys.tables t, sys.table_types ts WHERE t.type = ts.table_type_id AND ts.table_type_name = 'TABLE' AND NOT t.system);\n"
2016 : " IF i IS NOT NULL THEN\n"
2017 : " DECLARE M INT;\n"
2018 : " SET M = (SELECT MAX(t.id) FROM sys.tables t, sys.table_types ts WHERE t.type = ts.table_type_id AND ts.table_type_name = 'TABLE' AND NOT t.system);\n"
2019 : " DECLARE sch STRING;\n"
2020 : " DECLARE tbl STRING;\n"
2021 : " WHILE i IS NOT NULL AND i <= M DO\n"
2022 : " SET sch = (SELECT s.name FROM sys.tables t, sys.schemas s WHERE s.id = t.schema_id AND t.id = i);\n"
2023 : " SET tbl = (SELECT t.name FROM sys.tables t, sys.schemas s WHERE s.id = t.schema_id AND t.id = i);\n"
2024 : " CALL sys.dump_table_data(sch, tbl);\n"
2025 : " SET i = (SELECT MIN(t.id) FROM sys.tables t, sys.table_types ts WHERE t.type = ts.table_type_id AND ts.table_type_name = 'TABLE' AND NOT t.system AND t.id > i);\n"
2026 : " END WHILE;\n"
2027 : " END IF;\n"
2028 : "END;\n"
2029 : "CREATE VIEW sys.dump_create_users AS\n"
2030 : " SELECT\n"
2031 : " 'CREATE USER ' || sys.dq(ui.name) || ' WITH ENCRYPTED PASSWORD ' ||\n"
2032 : " sys.sq(sys.password_hash(ui.name)) ||\n"
2033 : " ' NAME ' || sys.sq(ui.fullname) || ' SCHEMA sys' || ifthenelse(ui.schema_path = '\"sys\"', '', ' SCHEMA PATH ' || sys.sq(ui.schema_path)) || ';' stmt,\n"
2034 : " ui.name user_name\n"
2035 : " FROM sys.db_user_info ui, sys.schemas s\n"
2036 : " WHERE ui.default_schema = s.id\n"
2037 : " AND ui.name <> 'monetdb'\n"
2038 : " AND ui.name <> '.snapshot';\n");
2039 :
2040 0 : pos += snprintf(buf + pos, bufsize - pos,
2041 : "CREATE VIEW sys.describe_tables AS\n"
2042 : " SELECT\n"
2043 : " t.id o,\n"
2044 : " s.name sch,\n"
2045 : " t.name tab,\n"
2046 : " ts.table_type_name typ,\n"
2047 : " (SELECT\n"
2048 : " ' (' ||\n"
2049 : " GROUP_CONCAT(\n"
2050 : " sys.DQ(c.name) || ' ' ||\n"
2051 : " sys.describe_type(c.type, c.type_digits, c.type_scale) ||\n"
2052 : " ifthenelse(c.\"null\" = 'false', ' NOT NULL', '')\n"
2053 : " , ', ') || ')'\n"
2054 : " FROM sys._columns c\n"
2055 : " WHERE c.table_id = t.id) col,\n"
2056 : " CASE ts.table_type_name\n"
2057 : " WHEN 'REMOTE TABLE' THEN\n"
2058 : " sys.get_remote_table_expressions(s.name, t.name)\n"
2059 : " WHEN 'MERGE TABLE' THEN\n"
2060 : " sys.get_merge_table_partition_expressions(t.id)\n"
2061 : " WHEN 'VIEW' THEN\n"
2062 : " sys.schema_guard(s.name, t.name, t.query)\n"
2063 : " ELSE\n"
2064 : " ''\n"
2065 : " END opt\n"
2066 : " FROM sys.schemas s, sys.table_types ts, sys.tables t\n"
2067 : " WHERE ts.table_type_name IN ('TABLE', 'VIEW', 'MERGE TABLE', 'REMOTE TABLE', 'REPLICA TABLE', 'UNLOGGED TABLE')\n"
2068 : " AND t.system = FALSE\n"
2069 : " AND s.id = t.schema_id\n"
2070 : " AND ts.table_type_id = t.type\n"
2071 : " AND s.name <> 'tmp';\n"
2072 : "GRANT SELECT ON sys.describe_tables TO PUBLIC;\n"
2073 : "CREATE VIEW sys.dump_tables AS\n"
2074 : " SELECT\n"
2075 : " t.o o,\n"
2076 : " CASE\n"
2077 : " WHEN t.typ <> 'VIEW' THEN\n"
2078 : " 'CREATE ' || t.typ || ' ' || sys.FQN(t.sch, t.tab) || t.col || t.opt || ';'\n"
2079 : " ELSE\n"
2080 : " t.opt\n"
2081 : " END stmt,\n"
2082 : " t.sch schema_name,\n"
2083 : " t.tab table_name\n"
2084 : " FROM sys.describe_tables t;\n"
2085 : "CREATE FUNCTION sys.dump_database(describe BOOLEAN) RETURNS TABLE(o int, stmt STRING)\n"
2086 : "BEGIN\n"
2087 : " SET SCHEMA sys;\n"
2088 : " TRUNCATE sys.dump_statements;\n"
2089 : " INSERT INTO sys.dump_statements VALUES (1, 'START TRANSACTION;');\n"
2090 : " INSERT INTO sys.dump_statements VALUES (2, 'SET SCHEMA \"sys\";');\n"
2091 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_roles;\n"
2092 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_users;\n"
2093 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_schemas;\n"
2094 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_user_defined_types;\n"
2095 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_add_schemas_to_users;\n"
2096 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_grant_user_privileges;\n"
2097 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_sequences;\n"
2098 : " --functions and table-likes can be interdependent. They should be inserted in the order of their catalogue id.\n"
2099 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(ORDER BY stmts.o), stmts.s\n"
2100 : " FROM (\n"
2101 : " SELECT f.o, f.stmt FROM sys.dump_functions f\n"
2102 : " UNION ALL\n"
2103 : " SELECT t.o, t.stmt FROM sys.dump_tables t\n"
2104 : " ) AS stmts(o, s);\n"
2105 : " -- dump table data before adding constraints and fixing sequences\n"
2106 : " IF NOT DESCRIBE THEN\n"
2107 : " CALL sys.dump_table_data();\n"
2108 : " END IF;\n"
2109 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_start_sequences;\n"
2110 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_defaults;\n"
2111 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_constraint_type;\n"
2112 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_indices;\n"
2113 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_foreign_keys;\n"
2114 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_partition_tables;\n"
2115 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_triggers;\n"
2116 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_comments;\n"
2117 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_grants;\n"
2118 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_grants;\n"
2119 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_function_grants;\n"
2120 : " --TODO Improve performance of dump_table_data.\n"
2121 : " --TODO loaders ,procedures, window and filter sys.functions.\n"
2122 : " --TODO look into order dependent group_concat\n"
2123 : " INSERT INTO sys.dump_statements VALUES ((SELECT COUNT(*) FROM sys.dump_statements) + 1, 'COMMIT;');\n"
2124 : " RETURN sys.dump_statements;\n"
2125 : "END;\n");
2126 0 : pos += snprintf(buf + pos, bufsize - pos,
2127 : "update sys._tables set system = true where name in ('describe_partition_tables', 'dump_partition_tables', 'dump_sequences', 'dump_start_sequences', 'describe_tables', 'dump_tables', 'dump_create_users', 'dump_functions', 'dump_triggers') AND schema_id = 2000;\n");
2128 0 : pos += snprintf(buf + pos, bufsize - pos,
2129 : "update sys.functions set system = true where system <> true and name in ('dump_table_data') and schema_id = 2000 and type = %d;\n", F_PROC);
2130 0 : pos += snprintf(buf + pos, bufsize - pos,
2131 : "update sys.functions set system = true where system <> true and name in ('dump_database') and schema_id = 2000 and type = %d;\n", F_UNION);
2132 0 : pos += snprintf(buf + pos, bufsize - pos,
2133 : "update sys.functions set system = true where system <> true and name in ('schema_guard') and schema_id = 2000 and type = %d;\n", F_FUNC);
2134 :
2135 : /* 12_url.sql */
2136 0 : pos += snprintf(buf + pos, bufsize - pos,
2137 : "CREATE function sys.url_extract_host(url string, no_www bool) RETURNS STRING\n"
2138 : "EXTERNAL NAME url.\"extractURLHost\";\n"
2139 : "GRANT EXECUTE ON FUNCTION url_extract_host(string, bool) TO PUBLIC;\n"
2140 : "update sys.functions set system = true where system <> true and name = 'url_extract_host' and schema_id = 2000 and type = %d;\n", F_FUNC);
2141 :
2142 0 : assert(pos < bufsize);
2143 0 : printf("Running database upgrade commands:\n%s\n", buf);
2144 0 : fflush(stdout);
2145 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2146 : }
2147 96 : res_table_destroy(output);
2148 96 : output = NULL;
2149 96 : if (err != MAL_SUCCEED) {
2150 0 : GDKfree(buf);
2151 0 : return err;
2152 : }
2153 :
2154 : /* 10_sys_schema_extensions */
2155 : /* if the keyword LOCKED is in the list of keywords, upgrade */
2156 96 : pos = snprintf(buf, bufsize, "select keyword from sys.keywords where keyword = 'LOCKED';\n");
2157 96 : assert(pos < bufsize);
2158 96 : if ((err = SQLstatementIntern(c, buf, "update", true, false, &output)))
2159 0 : goto bailout;
2160 96 : if ((b = BBPquickdesc(output->cols[0].b)) && BATcount(b) > 0) {
2161 0 : pos = snprintf(buf, bufsize,
2162 : "ALTER TABLE sys.keywords SET READ WRITE;\n"
2163 : "DELETE FROM sys.keywords WHERE keyword IN ('LOCKED');\n");
2164 0 : assert(pos < bufsize);
2165 0 : printf("Running database upgrade commands:\n%s\n", buf);
2166 0 : fflush(stdout);
2167 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2168 0 : if (err == MAL_SUCCEED) {
2169 0 : pos = snprintf(buf, bufsize, "ALTER TABLE sys.keywords SET READ ONLY;\n");
2170 0 : assert(pos < bufsize);
2171 0 : printf("Running database upgrade commands:\n%s\n", buf);
2172 0 : fflush(stdout);
2173 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2174 : }
2175 : }
2176 96 : res_table_destroy(output);
2177 96 : output = NULL;
2178 96 : if (err != MAL_SUCCEED) {
2179 0 : GDKfree(buf);
2180 0 : return err;
2181 : }
2182 :
2183 : /* if the table type UNLOGGED TABLE is not in the list of table
2184 : * types, upgrade */
2185 96 : pos = snprintf(buf, bufsize, "select table_type_name from sys.table_types where table_type_name = 'UNLOGGED TABLE';\n");
2186 96 : assert(pos < bufsize);
2187 96 : if ((err = SQLstatementIntern(c, buf, "update", true, false, &output)))
2188 0 : goto bailout;
2189 96 : if ((b = BBPquickdesc(output->cols[0].b)) && BATcount(b) == 0) {
2190 0 : pos = snprintf(buf, bufsize,
2191 : "ALTER TABLE sys.table_types SET READ WRITE;\n"
2192 : "INSERT INTO sys.table_types VALUES (7, 'UNLOGGED TABLE');\n");
2193 0 : assert(pos < bufsize);
2194 0 : printf("Running database upgrade commands:\n%s\n", buf);
2195 0 : fflush(stdout);
2196 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2197 0 : if (err == MAL_SUCCEED) {
2198 0 : pos = snprintf(buf, bufsize, "ALTER TABLE sys.table_types SET READ ONLY;\n");
2199 0 : assert(pos < bufsize);
2200 0 : printf("Running database upgrade commands:\n%s\n", buf);
2201 0 : fflush(stdout);
2202 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2203 : }
2204 : }
2205 96 : res_table_destroy(output);
2206 96 : output = NULL;
2207 :
2208 : /* 16_tracelog */
2209 96 : pos = snprintf(buf, bufsize,
2210 : "select f.id "
2211 : "from sys.schemas s, "
2212 : "sys.functions f, "
2213 : "sys.auths a, "
2214 : "sys.privileges p, "
2215 : "sys.auths g, "
2216 : "sys.function_types ft, "
2217 : "sys.privilege_codes pc "
2218 : "where s.id = f.schema_id "
2219 : "and f.id = p.obj_id "
2220 : "and p.auth_id = a.id "
2221 : "and p.grantor = g.id "
2222 : "and p.privileges = pc.privilege_code_id "
2223 : "and f.type = ft.function_type_id "
2224 : "and s.name = 'sys' "
2225 : "and f.name = 'tracelog' "
2226 : "and ft.function_type_keyword = 'FUNCTION';\n");
2227 96 : assert(pos < bufsize);
2228 96 : if ((err = SQLstatementIntern(c, buf, "update", true, false, &output)))
2229 0 : goto bailout;
2230 96 : if ((b = BBPquickdesc(output->cols[0].b)) && BATcount(b) == 0) {
2231 0 : pos = snprintf(buf, bufsize,
2232 : "grant execute on function sys.tracelog to public;\n"
2233 : "grant select on sys.tracelog to public;\n");
2234 0 : assert(pos < bufsize);
2235 0 : printf("Running database upgrade commands:\n%s\n", buf);
2236 0 : fflush(stdout);
2237 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2238 : }
2239 96 : res_table_destroy(output);
2240 96 : output = NULL;
2241 96 : if (err != MAL_SUCCEED) {
2242 0 : GDKfree(buf);
2243 0 : return err;
2244 : }
2245 :
2246 96 : bailout:
2247 96 : if (output)
2248 0 : res_table_destroy(output);
2249 96 : GDKfree(buf);
2250 96 : return err; /* usually MAL_SUCCEED */
2251 : }
2252 :
2253 : static str
2254 96 : sql_update_jun2023(Client c, mvc *sql, sql_schema *s)
2255 : {
2256 96 : size_t bufsize = 65536, pos = 0;
2257 96 : char *err = NULL, *buf = GDKmalloc(bufsize);
2258 96 : res_table *output;
2259 96 : BAT *b;
2260 96 : sql_subtype t1, t2;
2261 :
2262 96 : (void) sql;
2263 96 : if (buf == NULL)
2264 0 : throw(SQL, __func__, SQLSTATE(HY013) MAL_MALLOC_FAIL);
2265 :
2266 : /* wlc/wlr support was removed */
2267 : {
2268 96 : sql_schema *wl = mvc_bind_schema(sql, "wlc");
2269 96 : sql_schema *wr = mvc_bind_schema(sql, "wlr");
2270 96 : if (wl != NULL || wr != NULL) {
2271 0 : if (wl)
2272 0 : wl->system = 0;
2273 0 : if (wr)
2274 0 : wr->system = 0;
2275 :
2276 0 : const char query[] =
2277 : "drop procedure if exists wlc.master() cascade;\n"
2278 : "drop procedure if exists wlc.master(string) cascade;\n"
2279 : "drop procedure if exists wlc.stop() cascade;\n"
2280 : "drop procedure if exists wlc.flush() cascade;\n"
2281 : "drop procedure if exists wlc.beat(int) cascade;\n"
2282 : "drop function if exists wlc.clock() cascade;\n"
2283 : "drop function if exists wlc.tick() cascade;\n"
2284 : "drop procedure if exists wlr.master(string) cascade;\n"
2285 : "drop procedure if exists wlr.stop() cascade;\n"
2286 : "drop procedure if exists wlr.accept() cascade;\n"
2287 : "drop procedure if exists wlr.replicate() cascade;\n"
2288 : "drop procedure if exists wlr.replicate(timestamp) cascade;\n"
2289 : "drop procedure if exists wlr.replicate(tinyint) cascade;\n"
2290 : "drop procedure if exists wlr.replicate(smallint) cascade;\n"
2291 : "drop procedure if exists wlr.replicate(integer) cascade;\n"
2292 : "drop procedure if exists wlr.replicate(bigint) cascade;\n"
2293 : "drop procedure if exists wlr.beat(integer) cascade;\n"
2294 : "drop function if exists wlr.clock() cascade;\n"
2295 : "drop function if exists wlr.tick() cascade;\n"
2296 : "drop schema if exists wlc cascade;\n"
2297 : "drop schema if exists wlr cascade;\n";
2298 0 : printf("Running database upgrade commands:\n%s\n", query);
2299 0 : fflush(stdout);
2300 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
2301 : }
2302 : }
2303 :
2304 : /* new function sys.regexp_replace */
2305 96 : allocator *old_sa = sql->sa;
2306 96 : if ((sql->sa = sa_create(sql->pa)) != NULL) {
2307 96 : list *l;
2308 96 : if ((l = sa_list(sql->sa)) != NULL) {
2309 96 : sql_subtype tp;
2310 96 : sql_find_subtype(&tp, "varchar", 0, 0);
2311 96 : list_append(l, &tp);
2312 96 : list_append(l, &tp);
2313 96 : list_append(l, &tp);
2314 96 : list_append(l, &tp);
2315 96 : if (!sql_bind_func_(sql, s->base.name, "regexp_replace", l, F_FUNC, true, true)) {
2316 0 : pos = snprintf(buf, bufsize,
2317 : "create function sys.regexp_replace(ori string, pat string, rep string, flg string)\n"
2318 : "returns string external name pcre.replace;\n"
2319 : "grant execute on function regexp_replace(string, string, string, string) to public;\n"
2320 : "create function sys.regexp_replace(ori string, pat string, rep string)\n"
2321 : "returns string\n"
2322 : "begin\n"
2323 : " return sys.regexp_replace(ori, pat, rep, '');\n"
2324 : "end;\n"
2325 : "grant execute on function regexp_replace(string, string, string) to public;\n"
2326 : "update sys.functions set system = true where system <> true and name = 'regexp_replace' and schema_id = 2000 and type = %d;\n",
2327 : F_FUNC);
2328 0 : assert(pos < bufsize);
2329 0 : sql->session->status = 0;
2330 0 : sql->errstr[0] = '\0';
2331 0 : printf("Running database upgrade commands:\n%s\n", buf);
2332 0 : fflush(stdout);
2333 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2334 : }
2335 96 : sa_destroy(sql->sa);
2336 : }
2337 : }
2338 96 : sql->sa = old_sa;
2339 :
2340 : /* fixes for handling single quotes in strings so that we can run
2341 : * with raw_strings after having created a database without (and
2342 : * v.v.) */
2343 96 : if ((err = SQLstatementIntern(c, "select id from sys.functions where name = 'dump_table_data' and schema_id = 2000 and func like '% R'')%';\n", "update", true, false, &output)) == NULL) {
2344 96 : if (((b = BBPquickdesc(output->cols[0].b)) && BATcount(b) == 0) || find_sql_table(sql->session->tr, s, "remote_user_info") == NULL) {
2345 0 : sql_table *t;
2346 0 : if ((t = mvc_bind_table(sql, s, "describe_tables")) != NULL)
2347 0 : t->system = 0;
2348 0 : if ((t = mvc_bind_table(sql, s, "dump_create_users")) != NULL)
2349 0 : t->system = 0;
2350 0 : if ((t = mvc_bind_table(sql, s, "dump_partition_tables")) != NULL)
2351 0 : t->system = 0;
2352 0 : if ((t = mvc_bind_table(sql, s, "dump_comments")) != NULL)
2353 0 : t->system = 0;
2354 0 : if ((t = mvc_bind_table(sql, s, "dump_tables")) != NULL)
2355 0 : t->system = 0;
2356 0 : pos = 0;
2357 0 : pos += snprintf(buf + pos, bufsize - pos,
2358 : "drop function if exists sys.dump_database(boolean) cascade;\n"
2359 : "drop procedure if exists sys.dump_table_data() cascade;\n"
2360 : "drop procedure if exists sys.dump_table_data(string, string) cascade;\n"
2361 : "drop view if exists sys.dump_tables cascade;\n"
2362 : "drop view if exists sys.dump_comments cascade;\n"
2363 : "drop function if exists sys.prepare_esc(string, string) cascade;\n"
2364 : "drop view if exists sys.dump_partition_tables cascade;\n"
2365 : "drop view if exists sys.dump_create_users cascade;\n"
2366 : "drop view if exists sys.describe_tables cascade;\n"
2367 : "drop function if exists sys.get_remote_table_expressions(string, string) cascade;\n"
2368 : "drop function if exists sys.remote_table_credentials(string) cascade;\n"
2369 : "drop function if exists sys.sq(string) cascade;\n");
2370 0 : if (find_sql_table(sql->session->tr, s, "remote_user_info") == NULL) {
2371 0 : pos += snprintf(buf + pos, bufsize - pos,
2372 : "create table sys.remote_user_info (table_id int, username varchar(1024), password varchar(256));\n"
2373 : "create function sys.decypher (cypher string) returns string external name sql.decypher;\n"
2374 : "update sys.functions set system = true where system <> true and name = 'decypher' and schema_id = 2000 and type = %d;\n"
2375 : "update sys._tables set system = true where system <> true and name = 'remote_user_info' and schema_id = 2000;\n",
2376 : F_FUNC);
2377 : }
2378 0 : pos += snprintf(buf + pos, bufsize - pos,
2379 : "CREATE FUNCTION sys.SQ (s STRING) RETURNS STRING BEGIN RETURN '''' || sys.replace(s,'''','''''') || ''''; END;\n"
2380 : "CREATE FUNCTION sys.get_remote_table_expressions(s STRING, t STRING) RETURNS STRING BEGIN\n"
2381 : " RETURN SELECT ' ON ' || sys.SQ(tt.query) || ' WITH USER ' || sys.SQ(username) || ' ENCRYPTED PASSWORD ' || sys.SQ(sys.decypher(\"password\")) FROM sys.remote_user_info r, sys._tables tt, sys.schemas ss where tt.name = t and ss.name = s and tt.schema_id = ss.id and r.table_id = tt.id;\n"
2382 : "END;\n"
2383 : "CREATE VIEW sys.describe_tables AS\n"
2384 : " SELECT\n"
2385 : " t.id o,\n"
2386 : " s.name sch,\n"
2387 : " t.name tab,\n"
2388 : " ts.table_type_name typ,\n"
2389 : " (SELECT\n"
2390 : " ' (' ||\n"
2391 : " GROUP_CONCAT(\n"
2392 : " sys.DQ(c.name) || ' ' ||\n"
2393 : " sys.describe_type(c.type, c.type_digits, c.type_scale) ||\n"
2394 : " ifthenelse(c.\"null\" = 'false', ' NOT NULL', '')\n"
2395 : " , ', ') || ')'\n"
2396 : " FROM sys._columns c\n"
2397 : " WHERE c.table_id = t.id) col,\n"
2398 : " CASE ts.table_type_name\n"
2399 : " WHEN 'REMOTE TABLE' THEN\n"
2400 : " sys.get_remote_table_expressions(s.name, t.name)\n"
2401 : " WHEN 'MERGE TABLE' THEN\n"
2402 : " sys.get_merge_table_partition_expressions(t.id)\n"
2403 : " WHEN 'VIEW' THEN\n"
2404 : " sys.schema_guard(s.name, t.name, t.query)\n"
2405 : " ELSE\n"
2406 : " ''\n"
2407 : " END opt\n"
2408 : " FROM sys.schemas s, sys.table_types ts, sys.tables t\n"
2409 : " WHERE ts.table_type_name IN ('TABLE', 'VIEW', 'MERGE TABLE', 'REMOTE TABLE', 'REPLICA TABLE', 'UNLOGGED TABLE')\n"
2410 : " AND t.system = FALSE\n"
2411 : " AND s.id = t.schema_id\n"
2412 : " AND ts.table_type_id = t.type\n"
2413 : " AND s.name <> 'tmp';\n"
2414 : "CREATE VIEW sys.dump_create_users AS\n"
2415 : " SELECT\n"
2416 : " 'CREATE USER ' || sys.dq(ui.name) || ' WITH ENCRYPTED PASSWORD ' ||\n"
2417 : " sys.sq(sys.password_hash(ui.name)) ||\n"
2418 : " ' NAME ' || sys.sq(ui.fullname) || ' SCHEMA sys' || ifthenelse(ui.schema_path = '\"sys\"', '', ' SCHEMA PATH ' || sys.sq(ui.schema_path)) || ';' stmt,\n"
2419 : " ui.name user_name\n"
2420 : " FROM sys.db_user_info ui, sys.schemas s\n"
2421 : " WHERE ui.default_schema = s.id\n"
2422 : " AND ui.name <> 'monetdb'\n"
2423 : " AND ui.name <> '.snapshot';\n"
2424 : "CREATE VIEW sys.dump_partition_tables AS\n"
2425 : " SELECT\n"
2426 : " 'ALTER TABLE ' || sys.FQN(m_sch, m_tbl) || ' ADD TABLE ' || sys.FQN(p_sch, p_tbl) ||\n"
2427 : " CASE\n"
2428 : " WHEN tpe = 'VALUES' THEN ' AS PARTITION IN (' || pvalues || ')'\n"
2429 : " WHEN tpe = 'RANGE' THEN ' AS PARTITION FROM ' || ifthenelse(minimum IS NOT NULL, sys.SQ(minimum), 'RANGE MINVALUE') || ' TO ' || ifthenelse(maximum IS NOT NULL, sys.SQ(maximum), 'RANGE MAXVALUE')\n"
2430 : " WHEN tpe = 'FOR NULLS' THEN ' AS PARTITION FOR NULL VALUES'\n"
2431 : " ELSE '' --'READ ONLY'\n"
2432 : " END ||\n"
2433 : " CASE WHEN tpe in ('VALUES', 'RANGE') AND with_nulls THEN ' WITH NULL VALUES' ELSE '' END ||\n"
2434 : " ';' stmt,\n"
2435 : " m_sch merge_schema_name,\n"
2436 : " m_tbl merge_table_name,\n"
2437 : " p_sch partition_schema_name,\n"
2438 : " p_tbl partition_table_name\n"
2439 : " FROM sys.describe_partition_tables;\n"
2440 : "CREATE VIEW sys.dump_tables AS\n"
2441 : " SELECT\n"
2442 : " t.o o,\n"
2443 : " CASE\n"
2444 : " WHEN t.typ <> 'VIEW' THEN\n"
2445 : " 'CREATE ' || t.typ || ' ' || sys.FQN(t.sch, t.tab) || t.col || t.opt || ';'\n"
2446 : " ELSE\n"
2447 : " t.opt\n"
2448 : " END stmt,\n"
2449 : " t.sch schema_name,\n"
2450 : " t.tab table_name\n"
2451 : " FROM sys.describe_tables t;\n"
2452 : "CREATE VIEW sys.dump_comments AS\n"
2453 : " SELECT 'COMMENT ON ' || c.tpe || ' ' || c.fqn || ' IS ' || sys.SQ(c.rem) || ';' stmt FROM sys.describe_comments c;\n"
2454 : "CREATE FUNCTION sys.prepare_esc(s STRING, t STRING) RETURNS STRING\n"
2455 : "BEGIN\n"
2456 : " RETURN\n"
2457 : " CASE\n"
2458 : " WHEN (t = 'varchar' OR t ='char' OR t = 'clob' OR t = 'json' OR t = 'geometry' OR t = 'url') THEN\n"
2459 : " 'CASE WHEN ' || sys.DQ(s) || ' IS NULL THEN ''null'' ELSE ' || 'sys.esc(' || sys.DQ(s) || ')' || ' END'\n"
2460 : " ELSE\n"
2461 : " 'CASE WHEN ' || sys.DQ(s) || ' IS NULL THEN ''null'' ELSE CAST(' || sys.DQ(s) || ' AS STRING) END'\n"
2462 : " END;\n"
2463 : "END;\n"
2464 : "CREATE PROCEDURE sys.dump_table_data(sch STRING, tbl STRING)\n"
2465 : "BEGIN\n"
2466 : " DECLARE tid INT;\n"
2467 : " SET tid = (SELECT MIN(t.id) FROM sys.tables t, sys.schemas s WHERE t.name = tbl AND t.schema_id = s.id AND s.name = sch);\n"
2468 : " IF tid IS NOT NULL THEN\n"
2469 : " DECLARE k INT;\n"
2470 : " DECLARE m INT;\n"
2471 : " SET k = (SELECT MIN(c.id) FROM sys.columns c WHERE c.table_id = tid);\n"
2472 : " SET m = (SELECT MAX(c.id) FROM sys.columns c WHERE c.table_id = tid);\n"
2473 : " IF k IS NOT NULL AND m IS NOT NULL THEN\n"
2474 : " DECLARE cname STRING;\n"
2475 : " DECLARE ctype STRING;\n"
2476 : " DECLARE _cnt INT;\n"
2477 : " SET cname = (SELECT c.name FROM sys.columns c WHERE c.id = k);\n"
2478 : " SET ctype = (SELECT c.type FROM sys.columns c WHERE c.id = k);\n"
2479 : " SET _cnt = (SELECT count FROM sys.storage(sch, tbl, cname));\n"
2480 : " IF _cnt > 0 THEN\n"
2481 : " DECLARE COPY_INTO_STMT STRING;\n"
2482 : " DECLARE SELECT_DATA_STMT STRING;\n"
2483 : " SET COPY_INTO_STMT = 'COPY ' || _cnt || ' RECORDS INTO ' || sys.FQN(sch, tbl) || '(' || sys.DQ(cname);\n"
2484 : " SET SELECT_DATA_STMT = 'SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), ' || sys.prepare_esc(cname, ctype);\n"
2485 : " WHILE (k < m) DO\n"
2486 : " SET k = (SELECT MIN(c.id) FROM sys.columns c WHERE c.table_id = tid AND c.id > k);\n"
2487 : " SET cname = (SELECT c.name FROM sys.columns c WHERE c.id = k);\n"
2488 : " SET ctype = (SELECT c.type FROM sys.columns c WHERE c.id = k);\n"
2489 : " SET COPY_INTO_STMT = (COPY_INTO_STMT || ', ' || sys.DQ(cname));\n"
2490 : " SET SELECT_DATA_STMT = (SELECT_DATA_STMT || '|| ''|'' || ' || sys.prepare_esc(cname, ctype));\n"
2491 : " END WHILE;\n"
2492 : " SET COPY_INTO_STMT = (COPY_INTO_STMT || R') FROM STDIN USING DELIMITERS ''|'',E''\\n'',''\"'';');\n"
2493 : " SET SELECT_DATA_STMT = (SELECT_DATA_STMT || ' FROM ' || sys.FQN(sch, tbl));\n"
2494 : " INSERT INTO sys.dump_statements VALUES ((SELECT COUNT(*) FROM sys.dump_statements) + 1, COPY_INTO_STMT);\n"
2495 : " CALL sys.EVAL('INSERT INTO sys.dump_statements ' || SELECT_DATA_STMT || ';');\n"
2496 : " END IF;\n"
2497 : " END IF;\n"
2498 : " END IF;\n"
2499 : " END;\n"
2500 : "CREATE PROCEDURE sys.dump_table_data()\n"
2501 : "BEGIN\n"
2502 : " DECLARE i INT;\n"
2503 : " SET i = (SELECT MIN(t.id) FROM sys.tables t, sys.table_types ts WHERE t.type = ts.table_type_id AND ts.table_type_name = 'TABLE' AND NOT t.system);\n"
2504 : " IF i IS NOT NULL THEN\n"
2505 : " DECLARE M INT;\n"
2506 : " SET M = (SELECT MAX(t.id) FROM sys.tables t, sys.table_types ts WHERE t.type = ts.table_type_id AND ts.table_type_name = 'TABLE' AND NOT t.system);\n"
2507 : " DECLARE sch STRING;\n"
2508 : " DECLARE tbl STRING;\n"
2509 : " WHILE i IS NOT NULL AND i <= M DO\n"
2510 : " SET sch = (SELECT s.name FROM sys.tables t, sys.schemas s WHERE s.id = t.schema_id AND t.id = i);\n"
2511 : " SET tbl = (SELECT t.name FROM sys.tables t, sys.schemas s WHERE s.id = t.schema_id AND t.id = i);\n"
2512 : " CALL sys.dump_table_data(sch, tbl);\n"
2513 : " SET i = (SELECT MIN(t.id) FROM sys.tables t, sys.table_types ts WHERE t.type = ts.table_type_id AND ts.table_type_name = 'TABLE' AND NOT t.system AND t.id > i);\n"
2514 : " END WHILE;\n"
2515 : " END IF;\n"
2516 : "END;\n"
2517 : "CREATE FUNCTION sys.dump_database(describe BOOLEAN) RETURNS TABLE(o int, stmt STRING)\n"
2518 : "BEGIN\n"
2519 : " SET SCHEMA sys;\n"
2520 : " TRUNCATE sys.dump_statements;\n"
2521 : " INSERT INTO sys.dump_statements VALUES (1, 'START TRANSACTION;');\n"
2522 : " INSERT INTO sys.dump_statements VALUES (2, 'SET SCHEMA \"sys\";');\n"
2523 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_roles;\n"
2524 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_users;\n"
2525 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_schemas;\n"
2526 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_user_defined_types;\n"
2527 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_add_schemas_to_users;\n"
2528 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_grant_user_privileges;\n"
2529 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_sequences;\n"
2530 : " --functions and table-likes can be interdependent. They should be inserted in the order of their catalogue id.\n"
2531 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(ORDER BY stmts.o), stmts.s\n"
2532 : " FROM (\n"
2533 : " SELECT f.o, f.stmt FROM sys.dump_functions f\n"
2534 : " UNION ALL\n"
2535 : " SELECT t.o, t.stmt FROM sys.dump_tables t\n"
2536 : " ) AS stmts(o, s);\n"
2537 : " -- dump table data before adding constraints and fixing sequences\n"
2538 : " IF NOT DESCRIBE THEN\n"
2539 : " CALL sys.dump_table_data();\n"
2540 : " END IF;\n"
2541 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_start_sequences;\n"
2542 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_defaults;\n"
2543 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_constraint_type;\n"
2544 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_indices;\n"
2545 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_foreign_keys;\n"
2546 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_partition_tables;\n"
2547 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_triggers;\n"
2548 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_comments;\n"
2549 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_grants;\n"
2550 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_grants;\n"
2551 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_function_grants;\n"
2552 : " --TODO Improve performance of dump_table_data.\n"
2553 : " --TODO loaders ,procedures, window and filter sys.functions.\n"
2554 : " --TODO look into order dependent group_concat\n"
2555 : " INSERT INTO sys.dump_statements VALUES ((SELECT COUNT(*) FROM sys.dump_statements) + 1, 'COMMIT;');\n"
2556 : " RETURN sys.dump_statements;\n"
2557 : "END;\n"
2558 : "update sys.functions set system = true where system <> true and name in ('sq', 'get_remote_table_expressions', 'prepare_esc') and schema_id = 2000 and type = %d;\n"
2559 : "update sys._tables set system = true where system <> true and name in ('describe_tables', 'dump_create_users', 'dump_partition_tables', 'dump_comments', 'dump_tables') and schema_id = 2000;\n"
2560 : "update sys.functions set system = true where system <> true and name = 'dump_table_data' and schema_id = 2000 and type = %d;\n"
2561 : "update sys.functions set system = true where system <> true and name = 'dump_database' and schema_id = 2000 and type = %d;\n"
2562 : "GRANT SELECT ON sys.describe_tables TO PUBLIC;\n",
2563 : F_FUNC, F_PROC, F_UNION);
2564 0 : assert(pos < bufsize);
2565 0 : printf("Running database upgrade commands:\n%s\n", buf);
2566 0 : fflush(stdout);
2567 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2568 : }
2569 96 : res_table_destroy(output);
2570 96 : output = NULL;
2571 : }
2572 :
2573 : /* Add new column 'function_id' to views
2574 : * sys.dependency_tables_on_functions and dependency_views_on_functions */
2575 : {
2576 96 : sql_table *t = find_sql_table(sql->session->tr, s, "dependency_tables_on_functions");
2577 96 : if (t != NULL && find_sql_column(t, "function_id") == NULL) {
2578 0 : t->system = 0; /* sys.dependency_tables_on_functions */
2579 0 : if ((t = mvc_bind_table(sql, s, "dependency_views_on_functions")) != NULL)
2580 0 : t->system = 0;
2581 0 : pos = 0;
2582 0 : pos += snprintf(buf + pos, bufsize - pos,
2583 : "drop view if exists sys.dependency_tables_on_functions cascade;\n"
2584 : "drop view if exists sys.dependency_views_on_functions cascade;\n"
2585 : "CREATE VIEW sys.dependency_tables_on_functions AS\n"
2586 : "SELECT t.schema_id AS table_schema_id, t.id AS table_id, t.name AS table_name,"
2587 : " f.id AS function_id, f.name AS function_name, f.type AS function_type, dep.depend_type AS depend_type\n"
2588 : " FROM sys.functions AS f, sys.tables AS t, sys.dependencies AS dep\n"
2589 : " WHERE t.id = dep.id AND f.id = dep.depend_id\n"
2590 : " AND dep.depend_type = 7 AND f.type <> 2 AND t.type NOT IN (1, 11)\n"
2591 : " ORDER BY t.name, t.schema_id, f.name, f.id;\n"
2592 : "GRANT SELECT ON sys.dependency_tables_on_functions TO PUBLIC;\n"
2593 : "CREATE VIEW sys.dependency_views_on_functions AS\n"
2594 : "SELECT v.schema_id AS view_schema_id, v.id AS view_id, v.name AS view_name,"
2595 : " f.id AS function_id, f.name AS function_name, f.type AS function_type, dep.depend_type AS depend_type\n"
2596 : " FROM sys.functions AS f, sys.tables AS v, sys.dependencies AS dep\n"
2597 : " WHERE v.id = dep.id AND f.id = dep.depend_id\n"
2598 : " AND dep.depend_type = 7 AND f.type <> 2 AND v.type IN (1, 11)\n"
2599 : " ORDER BY v.name, v.schema_id, f.name, f.id;\n"
2600 : "GRANT SELECT ON sys.dependency_views_on_functions TO PUBLIC;\n"
2601 : "update sys._tables set system = true where system <> true and name in "
2602 : "('dependency_tables_on_functions','dependency_views_on_functions') and schema_id = 2000;\n");
2603 0 : assert(pos < bufsize);
2604 0 : printf("Running database upgrade commands:\n%s\n", buf);
2605 0 : fflush(stdout);
2606 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2607 : }
2608 : }
2609 :
2610 96 : if (!sql_bind_func(sql, "sys", "database", NULL, NULL, F_FUNC, true, true)) {
2611 0 : sql->session->status = 0; /* if the function was not found clean the error */
2612 0 : sql->errstr[0] = '\0';
2613 0 : pos = snprintf(buf, bufsize,
2614 : "create function sys.database ()\n"
2615 : "returns string\n"
2616 : "external name inspect.\"getDatabaseName\";\n"
2617 : "grant execute on function sys.database() to public;\n"
2618 : "update sys.functions set system = true where system <> true and name = 'database' and schema_id = 2000 and type = %d;\n",
2619 : (int) F_FUNC);
2620 0 : printf("Running database upgrade commands:\n%s\n", buf);
2621 0 : fflush(stdout);
2622 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2623 : }
2624 :
2625 : /* Add new sysadmin procedure calls: stop, pause and resume with two
2626 : arguments, first arg is query OID and second the user username that
2627 : the query in bound to. */
2628 96 : sql_find_subtype(&t1, "bigint", 64, 0);
2629 96 : sql_find_subtype(&t2, "varchar", 0, 0);
2630 96 : if (!sql_bind_func(sql, "sys", "pause", &t1, &t2, F_PROC, true, true)) {
2631 0 : sql->session->status = 0; /* if the function was not found clean the error */
2632 0 : sql->errstr[0] = '\0';
2633 0 : const char query[] =
2634 : "create function sys.queue(username string) returns table(\"tag\" bigint, \"sessionid\" int, \"username\" string, \"started\" timestamp, \"status\" string, \"query\" string, \"finished\" timestamp, \"maxworkers\" int, \"footprint\" int) external name sysmon.queue;\n"
2635 : "create procedure sys.pause(tag bigint, username string) external name sysmon.pause;\n"
2636 : "create procedure sys.resume(tag bigint, username string) external name sysmon.resume;\n"
2637 : "create procedure sys.stop(tag bigint, username string) external name sysmon.stop;\n"
2638 : "update sys.functions set system = true where system <> true and mod = 'sysmon' and name in ('stop', 'pause', 'resume', 'queue');\n";
2639 0 : printf("Running database upgrade commands:\n%s\n", query);
2640 0 : fflush(stdout);
2641 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
2642 : }
2643 :
2644 : /* sys.settimeout and sys.setsession where removed */
2645 96 : if (sql_bind_func(sql, "sys", "settimeout", &t1, NULL, F_PROC, true, true)) {
2646 0 : const char query[] =
2647 : "drop procedure sys.settimeout(bigint) cascade;\n"
2648 : "drop procedure sys.settimeout(bigint, bigint) cascade;\n"
2649 : "drop procedure sys.setsession(bigint) cascade;\n";
2650 0 : printf("Running database upgrade commands:\n%s\n", query);
2651 0 : fflush(stdout);
2652 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
2653 : } else {
2654 96 : sql->session->status = 0; /* if the function was not found clean the error */
2655 96 : sql->errstr[0] = '\0';
2656 : }
2657 :
2658 96 : if (!sql_bind_func(sql, "sys", "jarowinkler", &t2, &t2, F_FUNC, true, true)) {
2659 0 : sql->session->status = 0; /* if the function was not found clean the error */
2660 0 : sql->errstr[0] = '\0';
2661 0 : pos = snprintf(buf, bufsize,
2662 : "create function sys.levenshtein(x string, y string)\n"
2663 : "returns int external name txtsim.levenshtein;\n"
2664 : "grant execute on function levenshtein(string, string) to public;\n"
2665 : "create function sys.levenshtein(x string, y string, insdel int, rep int)\n"
2666 : "returns int external name txtsim.levenshtein;\n"
2667 : "grant execute on function levenshtein(string, string, int, int) to public;\n"
2668 : "create function sys.levenshtein(x string, y string, insdel int, rep int, trans int)\n"
2669 : "returns int external name txtsim.levenshtein;\n"
2670 : "grant execute on function levenshtein(string, string, int, int, int) to public;\n"
2671 : "create filter function sys.maxlevenshtein(x string, y string, k int)\n"
2672 : "external name txtsim.maxlevenshtein;\n"
2673 : "grant execute on filter function maxlevenshtein(string, string, int) to public;\n"
2674 : "create filter function sys.maxlevenshtein(x string, y string, k int, insdel int, rep int)\n"
2675 : "external name txtsim.maxlevenshtein;\n"
2676 : "grant execute on filter function maxlevenshtein(string, string, int, int, int) to public;\n"
2677 : "create function sys.jarowinkler(x string, y string)\n"
2678 : "returns double external name txtsim.jarowinkler;\n"
2679 : "grant execute on function jarowinkler(string, string) to public;\n"
2680 : "create filter function minjarowinkler(x string, y string, threshold double)\n"
2681 : "external name txtsim.minjarowinkler;\n"
2682 : "grant execute on filter function minjarowinkler(string, string, double) to public;\n"
2683 : "create function sys.dameraulevenshtein(x string, y string)\n"
2684 : "returns int external name txtsim.dameraulevenshtein;\n"
2685 : "grant execute on function dameraulevenshtein(string, string) to public;\n"
2686 : "create function sys.dameraulevenshtein(x string, y string, insdel int, rep int, trans int)\n"
2687 : "returns int external name txtsim.dameraulevenshtein;\n"
2688 : "grant execute on function dameraulevenshtein(string, string, int, int, int) to public;\n"
2689 :
2690 : "create function sys.editdistance(x string, y string)\n"
2691 : "returns int external name txtsim.editdistance;\n"
2692 : "grant execute on function editdistance(string, string) to public;\n"
2693 : "create function sys.editdistance2(x string, y string)\n"
2694 : "returns int external name txtsim.editdistance2;\n"
2695 : "grant execute on function editdistance2(string, string) to public;\n"
2696 : "create function sys.soundex(x string)\n"
2697 : "returns string external name txtsim.soundex;\n"
2698 : "grant execute on function soundex(string) to public;\n"
2699 : "create function sys.difference(x string, y string)\n"
2700 : "returns int external name txtsim.stringdiff;\n"
2701 : "grant execute on function difference(string, string) to public;\n"
2702 : "create function sys.qgramnormalize(x string)\n"
2703 : "returns string external name txtsim.qgramnormalize;\n"
2704 : "grant execute on function qgramnormalize(string) to public;\n"
2705 :
2706 : "create function asciify(x string)\n"
2707 : "returns string external name str.asciify;\n"
2708 : "grant execute on function asciify(string) to public;\n"
2709 : "create function sys.startswith(x string, y string)\n"
2710 : "returns boolean external name str.startswith;\n"
2711 : "grant execute on function startswith(string, string) to public;\n"
2712 : "create function sys.startswith(x string, y string, icase boolean)\n"
2713 : "returns boolean external name str.startswith;\n"
2714 : "grant execute on function startswith(string, string, boolean) to public;\n"
2715 : "create filter function sys.startswith(x string, y string)\n"
2716 : "external name str.startswith;\n"
2717 : "grant execute on filter function startswith(string, string) to public;\n"
2718 : "create filter function sys.startswith(x string, y string, icase boolean)\n"
2719 : "external name str.startswith;\n"
2720 : "grant execute on filter function startswith(string, string, boolean) to public;\n"
2721 : "create function sys.endswith(x string, y string)\n"
2722 : "returns boolean external name str.endswith;\n"
2723 : "grant execute on function endswith(string, string) to public;\n"
2724 : "create function sys.endswith(x string, y string, icase boolean)\n"
2725 : "returns boolean external name str.endswith;\n"
2726 : "grant execute on function endswith(string, string, boolean) to public;\n"
2727 : "create filter function sys.endswith(x string, y string)\n"
2728 : "external name str.endswith;\n"
2729 : "grant execute on filter function endswith(string, string) to public;\n"
2730 : "create filter function sys.endswith(x string, y string, icase boolean)\n"
2731 : "external name str.endswith;\n"
2732 : "grant execute on filter function endswith(string, string, boolean) to public;\n"
2733 : "create function sys.contains(x string, y string)\n"
2734 : "returns boolean external name str.contains;\n"
2735 : "grant execute on function contains(string, string) to public;\n"
2736 : "create function sys.contains(x string, y string, icase boolean)\n"
2737 : "returns boolean external name str.contains;\n"
2738 : "grant execute on function contains(string, string, boolean) to public;\n"
2739 : "create filter function sys.contains(x string, y string)\n"
2740 : "external name str.contains;\n"
2741 : "grant execute on filter function contains(string, string) to public;\n"
2742 : "create filter function sys.contains(x string, y string, icase boolean)\n"
2743 : "external name str.contains;\n"
2744 : "grant execute on filter function contains(string, string, boolean) to public;\n"
2745 :
2746 : "update sys.functions set system = true where system <> true and name in ('levenshtein', 'dameraulevenshtein', 'jarowinkler', 'editdistance', 'editdistance2', 'soundex', 'difference', 'qgramnormalize') and schema_id = 2000 and type = %d;\n"
2747 : "update sys.functions set system = true where system <> true and name in ('maxlevenshtein', 'minjarowinkler') and schema_id = 2000 and type = %d;\n"
2748 : "update sys.functions set system = true where system <> true and name in ('asciify', 'startswith', 'endswith', 'contains') and schema_id = 2000 and type = %d;\n"
2749 : "update sys.functions set system = true where system <> true and name in ('startswith', 'endswith', 'contains') and schema_id = 2000 and type = %d;\n"
2750 :
2751 : "delete from sys.triggers where name = 'system_update_tables' and table_id = 2067;\n",
2752 : F_FUNC, F_FILT, F_FUNC, F_FILT);
2753 0 : assert(pos < bufsize);
2754 0 : printf("Running database upgrade commands:\n%s\n", buf);
2755 0 : fflush(stdout);
2756 0 : err = SQLstatementIntern(c, buf, "update", true, false, NULL);
2757 : }
2758 :
2759 : /* remote credentials where moved */
2760 96 : sql_trans *tr = sql->session->tr;
2761 96 : sqlstore *store = tr->store;
2762 96 : sql_table *remote_user_info = find_sql_table(tr, s, "remote_user_info");
2763 96 : sql_column *remote_user_info_id = find_sql_column(remote_user_info, "table_id");
2764 96 : BAT *rt_key = NULL, *rt_username = NULL, *rt_pwhash = NULL, *rt_uri = NULL, *rt_deleted = NULL;
2765 96 : if (!err && store->storage_api.count_col(tr, remote_user_info_id, 0) == 0 && BBPindex("M5system_auth_rt_key")) {
2766 :
2767 0 : rt_key = BATdescriptor(BBPindex("M5system_auth_rt_key"));
2768 0 : rt_uri = BATdescriptor(BBPindex("M5system_auth_rt_uri"));
2769 0 : rt_username = BATdescriptor(BBPindex("M5system_auth_rt_remoteuser"));
2770 0 : rt_pwhash = BATdescriptor(BBPindex("M5system_auth_rt_hashedpwd"));
2771 0 : rt_deleted = BATdescriptor(BBPindex("M5system_auth_rt_deleted"));
2772 0 : if (rt_key == NULL || rt_username == NULL || rt_pwhash == NULL || rt_uri == NULL || rt_deleted == NULL) {
2773 : /* cleanup remainders and continue or full stop ? */
2774 0 : BBPreclaim(rt_key);
2775 0 : BBPreclaim(rt_uri);
2776 0 : BBPreclaim(rt_username);
2777 0 : BBPreclaim(rt_pwhash);
2778 0 : BBPreclaim(rt_deleted);
2779 0 : throw(SQL, __func__, "cannot find M5system_auth bats");
2780 : }
2781 :
2782 0 : BATiter ik = bat_iterator(rt_key);
2783 0 : BATiter iu = bat_iterator(rt_username);
2784 0 : BATiter ip = bat_iterator(rt_pwhash);
2785 0 : for (oid p = 0; p < ik.count; p++) {
2786 0 : if (BUNfnd(rt_deleted, &p) == BUN_NONE) {
2787 0 : char *key = GDKstrdup(BUNtvar(ik, p));
2788 0 : char *username = BUNtvar(iu, p);
2789 0 : char *pwhash = BUNtvar(ip, p);
2790 :
2791 0 : if (!key) {
2792 0 : bat_iterator_end(&ik);
2793 0 : bat_iterator_end(&iu);
2794 0 : bat_iterator_end(&ip);
2795 0 : BBPunfix(rt_key->batCacheid);
2796 0 : BBPunfix(rt_username->batCacheid);
2797 0 : BBPunfix(rt_pwhash->batCacheid);
2798 0 : BBPunfix(rt_deleted->batCacheid);
2799 0 : throw(SQL, __func__, SQLSTATE(HY013) MAL_MALLOC_FAIL);
2800 : }
2801 0 : char *d = strchr(key, '.');
2802 : /* . not found simply skip */
2803 0 : if (d) {
2804 0 : *d++ = '\0';
2805 0 : sql_schema *s = find_sql_schema(tr, key);
2806 0 : if (s) {
2807 0 : sql_table *t = find_sql_table(tr, s, d);
2808 0 : if (t && store->table_api.table_insert(tr, remote_user_info, &t->base.id, &username, &pwhash) != LOG_OK) {
2809 0 : bat_iterator_end(&ik);
2810 0 : bat_iterator_end(&iu);
2811 0 : bat_iterator_end(&ip);
2812 0 : BBPunfix(rt_key->batCacheid);
2813 0 : BBPunfix(rt_username->batCacheid);
2814 0 : BBPunfix(rt_pwhash->batCacheid);
2815 0 : BBPunfix(rt_deleted->batCacheid);
2816 0 : GDKfree(key);
2817 0 : throw(SQL, __func__, "Failed to insert remote credentials during upgrade");
2818 : }
2819 : }
2820 : }
2821 0 : GDKfree(key);
2822 : }
2823 : }
2824 0 : bat_iterator_end(&ik);
2825 0 : bat_iterator_end(&iu);
2826 0 : bat_iterator_end(&ip);
2827 : }
2828 96 : if (!err && rt_key) {
2829 0 : bat rtauthbats[6];
2830 :
2831 0 : rtauthbats[0] = 0;
2832 0 : rtauthbats[1] = rt_key->batCacheid;
2833 0 : rtauthbats[2] = rt_uri->batCacheid;
2834 0 : rtauthbats[3] = rt_username->batCacheid;
2835 0 : rtauthbats[4] = rt_pwhash->batCacheid;
2836 0 : rtauthbats[5] = rt_deleted->batCacheid;
2837 :
2838 0 : if (BATmode(rt_key, true) != GDK_SUCCEED ||
2839 0 : BBPrename(rt_key, NULL) != 0 ||
2840 0 : BATmode(rt_username, true) != GDK_SUCCEED ||
2841 0 : BBPrename(rt_username, NULL) != 0 ||
2842 0 : BATmode(rt_pwhash, true) != GDK_SUCCEED ||
2843 0 : BBPrename(rt_pwhash, NULL) != 0 ||
2844 0 : BATmode(rt_uri, true) != GDK_SUCCEED ||
2845 0 : BBPrename(rt_uri, NULL) != 0 ||
2846 0 : BATmode(rt_deleted, true) != GDK_SUCCEED ||
2847 0 : BBPrename(rt_deleted, NULL) != 0 ||
2848 0 : TMsubcommit_list(rtauthbats, NULL, 6, -1) != GDK_SUCCEED) {
2849 0 : fprintf(stderr, "Committing removal of old remote user/password BATs failed\n");
2850 : }
2851 0 : BBPunfix(rt_key->batCacheid);
2852 0 : BBPunfix(rt_username->batCacheid);
2853 0 : BBPunfix(rt_pwhash->batCacheid);
2854 0 : BBPunfix(rt_uri->batCacheid);
2855 0 : BBPunfix(rt_deleted->batCacheid);
2856 : }
2857 :
2858 96 : GDKfree(buf);
2859 96 : return err; /* usually MAL_SUCCEED */
2860 : }
2861 :
2862 : static str
2863 96 : sql_update_jun2023_sp3(Client c, mvc *sql, sql_schema *s)
2864 : {
2865 96 : (void)s;
2866 96 : char *err = NULL;
2867 96 : sql_subtype t1, t2;
2868 :
2869 96 : sql_find_subtype(&t1, "timestamp", 0, 0);
2870 96 : sql_find_subtype(&t2, "varchar", 0, 0);
2871 :
2872 96 : if (!sql_bind_func(sql, "sys", "timestamp_to_str", &t1, &t2, F_FUNC, true, true)) {
2873 0 : sql->session->status = 0;
2874 0 : sql->errstr[0] = '\0';
2875 :
2876 0 : char *query = GDKmalloc(512);
2877 0 : if (query == NULL)
2878 0 : throw(SQL, __func__, SQLSTATE(HY013) MAL_MALLOC_FAIL);
2879 :
2880 0 : snprintf(query, 512, "CREATE FUNCTION timestamp_to_str(d TIMESTAMP, format STRING) RETURNS STRING "
2881 : "EXTERNAL NAME mtime.\"timestamp_to_str\";\n"
2882 : "GRANT EXECUTE ON FUNCTION timestamp_to_str(TIMESTAMP, STRING) TO PUBLIC;\n"
2883 : "UPDATE sys.functions SET system = true WHERE system <> true AND name = 'timestamp_to_str' "
2884 : "AND schema_id = 2000 and type = %d;\n", F_FUNC);
2885 :
2886 0 : printf("Running database upgrade commands:\n%s\n", query);
2887 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
2888 0 : GDKfree(query);
2889 : }
2890 :
2891 : return err; /* usually MAL_SUCCEED */
2892 : }
2893 :
2894 : static str
2895 96 : sql_update_dec2023_geom(Client c, mvc *sql, sql_schema *s)
2896 : {
2897 96 : sql_subtype tp;
2898 96 : char *err = NULL;
2899 :
2900 : /* the shp module was changed: drop the old stuff if it exists, only
2901 : * add the new stuff if the appropriate module is available */
2902 96 : sql_find_subtype(&tp, "varchar", 0, 0);
2903 : /* Drop old SHP procedures */
2904 96 : if (sql_bind_func(sql, s->base.name, "shpattach", &tp, NULL, F_PROC, true, true)) {
2905 0 : if ((err = sql_drop_shp(c)) != NULL)
2906 : return err;
2907 : } else {
2908 96 : sql->session->status = 0; /* if the shpattach function was not found clean the error */
2909 96 : sql->errstr[0] = '\0';
2910 : }
2911 : #ifdef HAVE_GEOM
2912 96 : if (backend_has_module(&(int){0}, "geom")) {
2913 : #ifdef HAVE_SHP
2914 96 : if (backend_has_module(&(int){0}, "shp")) {
2915 : /* if shpload with two varchar args does not exist, add the
2916 : * procedures */
2917 96 : if (!sql_bind_func(sql, s->base.name, "shpload", &tp, &tp, F_PROC, true, true)) {
2918 0 : sql->session->status = 0;
2919 0 : sql->errstr[0] = '\0';
2920 0 : if ((err = sql_create_shp(c)) != NULL)
2921 0 : return err;
2922 : }
2923 : }
2924 : #endif
2925 96 : sql_find_subtype(&tp, "geometry", 0, 0);
2926 96 : if (!sql_bind_func(sql, s->base.name, "st_intersects_noindex", &tp, &tp, F_FILT, true, true)) {
2927 0 : sql->session->status = 0;
2928 0 : sql->errstr[0] = '\0';
2929 0 : sql_table *t;
2930 0 : if ((t = mvc_bind_table(sql, s, "geometry_columns")) != NULL)
2931 0 : t->system = 0;
2932 0 : const char query[] =
2933 : "drop function if exists sys.st_intersects(geometry, geometry) cascade;\n"
2934 : "drop function if exists sys.st_dwithin(geometry, geometry, double) cascade;\n"
2935 : "drop view if exists sys.geometry_columns cascade;\n"
2936 : "drop function if exists sys.st_collect(geometry, geometry) cascade;\n"
2937 : "drop aggregate if exists sys.st_collect(geometry) cascade;\n"
2938 : "drop aggregate if exists sys.st_makeline(geometry) cascade;\n"
2939 : "create view sys.geometry_columns as\n"
2940 : " select cast(null as varchar(1)) as f_table_catalog,\n"
2941 : " s.name as f_table_schema,\n"
2942 : " t.name as f_table_name,\n"
2943 : " c.name as f_geometry_column,\n"
2944 : " cast(has_z(c.type_digits) + has_m(c.type_digits) +2 as integer) as coord_dimension,\n"
2945 : " c.type_scale as srid,\n"
2946 : " get_type(c.type_digits, 0) as geometry_type\n"
2947 : " from sys.columns c, sys.tables t, sys.schemas s\n"
2948 : " where c.table_id = t.id and t.schema_id = s.id\n"
2949 : " and c.type in (select sqlname from sys.types where systemname in ('wkb', 'wkba'));\n"
2950 : "GRANT SELECT ON sys.geometry_columns TO PUBLIC;\n"
2951 : "CREATE FUNCTION ST_Collect(geom1 Geometry, geom2 Geometry) RETURNS Geometry EXTERNAL NAME geom.\"Collect\";\n"
2952 : "GRANT EXECUTE ON FUNCTION ST_Collect(Geometry, Geometry) TO PUBLIC;\n"
2953 : "CREATE AGGREGATE ST_Collect(geom Geometry) RETURNS Geometry external name aggr.\"Collect\";\n"
2954 : "GRANT EXECUTE ON AGGREGATE ST_Collect(Geometry) TO PUBLIC;\n"
2955 : "CREATE FUNCTION ST_DistanceGeographic(geom1 Geometry, geom2 Geometry) RETURNS double EXTERNAL NAME geom.\"DistanceGeographic\";\n"
2956 : "GRANT EXECUTE ON FUNCTION ST_DistanceGeographic(Geometry, Geometry) TO PUBLIC;\n"
2957 : "CREATE FILTER FUNCTION ST_DWithinGeographic(geom1 Geometry, geom2 Geometry, distance double) EXTERNAL NAME geom.\"DWithinGeographic\";\n"
2958 : "GRANT EXECUTE ON FILTER ST_DWithinGeographic(Geometry, Geometry, double) TO PUBLIC;\n"
2959 : "CREATE FILTER FUNCTION ST_DWithin(geom1 Geometry, geom2 Geometry, distance double) EXTERNAL NAME rtree.\"DWithin\";\n"
2960 : "GRANT EXECUTE ON FILTER ST_DWithin(Geometry, Geometry, double) TO PUBLIC;\n"
2961 : "CREATE FILTER FUNCTION ST_DWithin_NoIndex(geom1 Geometry, geom2 Geometry, distance double) EXTERNAL NAME geom.\"DWithin_noindex\";\n"
2962 : "GRANT EXECUTE ON FILTER ST_DWithin_NoIndex(Geometry, Geometry, double) TO PUBLIC;\n"
2963 : "CREATE FUNCTION ST_DWithin2(geom1 Geometry, geom2 Geometry, bbox1 mbr, bbox2 mbr, dst double) RETURNS boolean EXTERNAL NAME geom.\"DWithin2\";\n"
2964 : "GRANT EXECUTE ON FUNCTION ST_DWithin2(Geometry, Geometry, mbr, mbr, double) TO PUBLIC;\n"
2965 : "CREATE FILTER FUNCTION ST_IntersectsGeographic(geom1 Geometry, geom2 Geometry) EXTERNAL NAME geom.\"IntersectsGeographic\";\n"
2966 : "GRANT EXECUTE ON FILTER ST_IntersectsGeographic(Geometry, Geometry) TO PUBLIC;\n"
2967 : "CREATE FILTER FUNCTION ST_Intersects(geom1 Geometry, geom2 Geometry) EXTERNAL NAME rtree.\"Intersects\";\n"
2968 : "GRANT EXECUTE ON FILTER ST_Intersects(Geometry, Geometry) TO PUBLIC;\n"
2969 : "CREATE FILTER FUNCTION ST_Intersects_NoIndex(geom1 Geometry, geom2 Geometry) EXTERNAL NAME geom.\"Intersects_noindex\";\n"
2970 : "GRANT EXECUTE ON FILTER ST_Intersects_NoIndex(Geometry, Geometry) TO PUBLIC;\n"
2971 : "CREATE AGGREGATE ST_MakeLine(geom Geometry) RETURNS Geometry external name aggr.\"MakeLine\";\n"
2972 : "GRANT EXECUTE ON AGGREGATE ST_MakeLine(Geometry) TO PUBLIC;\n"
2973 : "update sys.functions set system = true where system <> true and schema_id = 2000 and name in ('st_collect', 'st_distancegeographic', 'st_dwithingeographic', 'st_dwithin', 'st_dwithin_noindex', 'st_dwithin2', 'st_intersectsgeographic', 'st_intersects', 'st_intersects_noindex', 'st_makeline');\n"
2974 : "update sys._tables set system = true where system <> true and schema_id = 2000 and name = 'geometry_columns';\n";
2975 0 : printf("Running database upgrade commands:\n%s\n", query);
2976 0 : fflush(stdout);
2977 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
2978 : }
2979 : }
2980 : #endif
2981 96 : return err;
2982 : }
2983 :
2984 : static str
2985 96 : sql_update_dec2023(Client c, mvc *sql, sql_schema *s)
2986 : {
2987 96 : sql_subtype tp;
2988 96 : sql_schema *info;
2989 96 : char *err = NULL;
2990 96 : res_table *output = NULL;
2991 :
2992 96 : sql_find_subtype(&tp, "varchar", 0, 0);
2993 96 : if (sql_bind_func(sql, s->base.name, "similarity", &tp, &tp, F_FUNC, true, true)) {
2994 0 : const char query[] = "drop function sys.similarity(string, string) cascade;\n";
2995 0 : printf("Running database upgrade commands:\n%s\n", query);
2996 0 : fflush(stdout);
2997 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
2998 : } else {
2999 96 : sql->session->status = 0; /* if the function was not found clean the error */
3000 96 : sql->errstr[0] = '\0';
3001 : }
3002 :
3003 96 : if (mvc_bind_table(sql, s, "describe_accessible_tables") == NULL) {
3004 0 : sql->session->status = 0; /* if the view was not found clean the error */
3005 0 : sql->errstr[0] = '\0';
3006 0 : const char query[] =
3007 : "CREATE VIEW sys.describe_accessible_tables AS\n"
3008 : " SELECT\n"
3009 : " schemas.name AS schema,\n"
3010 : " tables.name AS table,\n"
3011 : " tt.table_type_name AS table_type,\n"
3012 : " pc.privilege_code_name AS privs,\n"
3013 : " p.privileges AS privs_code\n"
3014 : " FROM privileges p\n"
3015 : " JOIN sys.roles ON p.auth_id = roles.id\n"
3016 : " JOIN sys.tables ON p.obj_id = tables.id\n"
3017 : " JOIN sys.table_types tt ON tables.type = tt.table_type_id\n"
3018 : " JOIN sys.schemas ON tables.schema_id = schemas.id\n"
3019 : " JOIN sys.privilege_codes pc ON p.privileges = pc.privilege_code_id\n"
3020 : " WHERE roles.name = current_role;\n"
3021 : "GRANT SELECT ON sys.describe_accessible_tables TO PUBLIC;\n"
3022 : "update sys._tables set system = true where system <> true and schema_id = 2000 and name = 'describe_accessible_tables';\n"
3023 :
3024 : /* PYTHON_MAP and PYTHON3_MAP have been removed */
3025 : "alter table sys.function_languages set read write;\n"
3026 : "delete from sys.function_languages where language_keyword like 'PYTHON%_MAP';\n"
3027 : /* for these two, also see load_func() */
3028 : "update sys.functions set language = language - 1 where language in (7, 11);\n"
3029 : "update sys.functions set mod = 'pyapi3' where mod in ('pyapi', 'pyapi3map');\n"
3030 : "commit;\n";
3031 0 : printf("Running database upgrade commands:\n%s\n", query);
3032 0 : fflush(stdout);
3033 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
3034 0 : if (err == MAL_SUCCEED) {
3035 0 : const char query2[] = "alter table sys.function_languages set read only;\n";
3036 0 : printf("Running database upgrade commands:\n%s\n", query2);
3037 0 : fflush(stdout);
3038 0 : err = SQLstatementIntern(c, query2, "update", true, false, NULL);
3039 : }
3040 : }
3041 :
3042 : /* 52_describe.sql changes to update sys.describe_comments view */
3043 96 : if ((err = SQLstatementIntern(c, "select id from sys.tables where name = 'describe_comments' and schema_id = 2000 and query like '% not t.system%';", "update", true, false, &output)) == NULL) {
3044 96 : BAT *b;
3045 96 : if ((b = BBPquickdesc(output->cols[0].b)) && BATcount(b) == 0) {
3046 0 : sql_table *t;
3047 : /* set views internally to non-system to allow drop commands to succeed without error */
3048 0 : if ((t = mvc_bind_table(sql, s, "describe_comments")) != NULL)
3049 0 : t->system = 0;
3050 0 : if ((t = mvc_bind_table(sql, s, "dump_comments")) != NULL)
3051 0 : t->system = 0;
3052 :
3053 0 : const char cmds[] =
3054 : "DROP FUNCTION IF EXISTS sys.dump_database(BOOLEAN) CASCADE;\n"
3055 : "DROP VIEW IF EXISTS sys.dump_comments CASCADE;\n"
3056 : "DROP VIEW IF EXISTS sys.describe_comments CASCADE;\n"
3057 : "CREATE VIEW sys.describe_comments AS\n"
3058 : " SELECT o.id AS id, o.tpe AS tpe, o.nme AS fqn, cm.remark AS rem\n"
3059 : " FROM (\n"
3060 : " SELECT id, 'SCHEMA', sys.DQ(name) FROM sys.schemas WHERE NOT system\n"
3061 : " UNION ALL\n"
3062 : " SELECT t.id, ifthenelse(ts.table_type_name = 'VIEW', 'VIEW', 'TABLE'), sys.FQN(s.name, t.name)\n"
3063 : " FROM sys.schemas s JOIN sys._tables t ON s.id = t.schema_id JOIN sys.table_types ts ON t.type = ts.table_type_id\n"
3064 : " WHERE NOT t.system\n"
3065 : " UNION ALL\n"
3066 : " SELECT c.id, 'COLUMN', sys.FQN(s.name, t.name) || '.' || sys.DQ(c.name) FROM sys.columns c, sys._tables t, sys.schemas s WHERE NOT t.system AND c.table_id = t.id AND t.schema_id = s.id\n"
3067 : " UNION ALL\n"
3068 : " SELECT idx.id, 'INDEX', sys.FQN(s.name, idx.name) FROM sys.idxs idx, sys._tables t, sys.schemas s WHERE NOT t.system AND idx.table_id = t.id AND t.schema_id = s.id\n"
3069 : " UNION ALL\n"
3070 : " SELECT seq.id, 'SEQUENCE', sys.FQN(s.name, seq.name) FROM sys.sequences seq, sys.schemas s WHERE seq.schema_id = s.id\n"
3071 : " UNION ALL\n"
3072 : " SELECT f.id, ft.function_type_keyword, qf.nme FROM sys.functions f, sys.function_types ft, sys.schemas s, sys.fully_qualified_functions qf\n"
3073 : " WHERE NOT f.system AND f.type = ft.function_type_id AND f.schema_id = s.id AND qf.id = f.id\n"
3074 : " ) AS o(id, tpe, nme)\n"
3075 : " JOIN sys.comments cm ON cm.id = o.id;\n"
3076 : "GRANT SELECT ON sys.describe_comments TO PUBLIC;\n"
3077 : "CREATE VIEW sys.dump_comments AS\n"
3078 : " SELECT 'COMMENT ON ' || c.tpe || ' ' || c.fqn || ' IS ' || sys.SQ(c.rem) || ';' stmt FROM sys.describe_comments c;\n"
3079 : "CREATE FUNCTION sys.dump_database(describe BOOLEAN) RETURNS TABLE(o int, stmt STRING)\n"
3080 : "BEGIN\n"
3081 : " SET SCHEMA sys;\n"
3082 : " TRUNCATE sys.dump_statements;\n"
3083 : " INSERT INTO sys.dump_statements VALUES (1, 'START TRANSACTION;');\n"
3084 : " INSERT INTO sys.dump_statements VALUES (2, 'SET SCHEMA \"sys\";');\n"
3085 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_roles;\n"
3086 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_users;\n"
3087 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_schemas;\n"
3088 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_user_defined_types;\n"
3089 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_add_schemas_to_users;\n"
3090 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_grant_user_privileges;\n"
3091 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_sequences;\n"
3092 : " --functions and table-likes can be interdependent. They should be inserted in the order of their catalogue id.\n"
3093 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(ORDER BY stmts.o), stmts.s\n"
3094 : " FROM (\n"
3095 : " SELECT f.o, f.stmt FROM sys.dump_functions f\n"
3096 : " UNION ALL\n"
3097 : " SELECT t.o, t.stmt FROM sys.dump_tables t\n"
3098 : " ) AS stmts(o, s);\n"
3099 : " IF NOT DESCRIBE THEN\n"
3100 : " CALL sys.dump_table_data();\n"
3101 : " END IF;\n"
3102 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_start_sequences;\n"
3103 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_defaults;\n"
3104 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_constraint_type;\n"
3105 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_indices;\n"
3106 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_foreign_keys;\n"
3107 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_partition_tables;\n"
3108 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_triggers;\n"
3109 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_comments;\n"
3110 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_grants;\n"
3111 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_grants;\n"
3112 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_function_grants;\n"
3113 : " INSERT INTO sys.dump_statements VALUES ((SELECT COUNT(*) FROM sys.dump_statements) + 1, 'COMMIT;');\n"
3114 : " RETURN sys.dump_statements;\n"
3115 : "END;\n"
3116 : "update sys._tables set system = true where schema_id = 2000 and name in ('describe_comments','dump_comments');\n"
3117 : "update sys.functions set system = true where system <> true and schema_id = 2000 and name = 'dump_database' and type = 5;\n";
3118 :
3119 0 : printf("Running database upgrade commands:\n%s\n", cmds);
3120 0 : fflush(stdout);
3121 0 : err = SQLstatementIntern(c, cmds, "update", true, false, NULL);
3122 : }
3123 96 : res_table_destroy(output);
3124 96 : output = NULL;
3125 : }
3126 :
3127 : /* 52_describe.sql New function sys.sql_datatype(mtype varchar(999), digits integer, tscale integer, nameonly boolean, shortname boolean) */
3128 96 : allocator *old_sa = sql->sa;
3129 96 : if ((sql->sa = sa_create(sql->pa)) != NULL) {
3130 96 : list *l;
3131 96 : if ((l = sa_list(sql->sa)) != NULL) {
3132 96 : sql_subtype t1, t2;
3133 96 : sql_find_subtype(&t1, "int", 0, 0);
3134 96 : sql_find_subtype(&t2, "boolean", 0, 0);
3135 96 : list_append(l, &tp);
3136 96 : list_append(l, &t1);
3137 96 : list_append(l, &t1);
3138 96 : list_append(l, &t2);
3139 96 : list_append(l, &t2);
3140 96 : if (!sql_bind_func_(sql, s->base.name, "sql_datatype", l, F_FUNC, true, true)) {
3141 0 : const char cmds[] =
3142 : "CREATE FUNCTION sys.sql_datatype(mtype varchar(999), digits integer, tscale integer, nameonly boolean, shortname boolean)\n"
3143 : " RETURNS varchar(1024)\n"
3144 : "BEGIN\n"
3145 : " RETURN\n"
3146 : " CASE mtype\n"
3147 : " WHEN 'char' THEN sys.ifthenelse(nameonly OR digits <= 1, sys.ifthenelse(shortname, 'CHAR', 'CHARACTER'), sys.ifthenelse(shortname, 'CHAR(', 'CHARACTER(') || digits || ')')\n"
3148 : " WHEN 'varchar' THEN sys.ifthenelse(nameonly OR digits = 0, sys.ifthenelse(shortname, 'VARCHAR', 'CHARACTER VARYING'), sys.ifthenelse(shortname, 'VARCHAR(', 'CHARACTER VARYING(') || digits || ')')\n"
3149 : " WHEN 'clob' THEN sys.ifthenelse(nameonly OR digits = 0, sys.ifthenelse(shortname, 'CLOB', 'CHARACTER LARGE OBJECT'), sys.ifthenelse(shortname, 'CLOB(', 'CHARACTER LARGE OBJECT(') || digits || ')')\n"
3150 : " WHEN 'blob' THEN sys.ifthenelse(nameonly OR digits = 0, sys.ifthenelse(shortname, 'BLOB', 'BINARY LARGE OBJECT'), sys.ifthenelse(shortname, 'BLOB(', 'BINARY LARGE OBJECT(') || digits || ')')\n"
3151 : " WHEN 'int' THEN 'INTEGER'\n"
3152 : " WHEN 'bigint' THEN 'BIGINT'\n"
3153 : " WHEN 'smallint' THEN 'SMALLINT'\n"
3154 : " WHEN 'tinyint' THEN 'TINYINT'\n"
3155 : " WHEN 'hugeint' THEN 'HUGEINT'\n"
3156 : " WHEN 'boolean' THEN 'BOOLEAN'\n"
3157 : " WHEN 'date' THEN 'DATE'\n"
3158 : " WHEN 'time' THEN sys.ifthenelse(nameonly OR digits = 1, 'TIME', 'TIME(' || (digits -1) || ')')\n"
3159 : " WHEN 'timestamp' THEN sys.ifthenelse(nameonly OR digits = 7, 'TIMESTAMP', 'TIMESTAMP(' || (digits -1) || ')')\n"
3160 : " WHEN 'timestamptz' THEN sys.ifthenelse(nameonly OR digits = 7, 'TIMESTAMP WITH TIME ZONE', 'TIMESTAMP(' || (digits -1) || ') WITH TIME ZONE')\n"
3161 : " WHEN 'timetz' THEN sys.ifthenelse(nameonly OR digits = 1, 'TIME WITH TIME ZONE', 'TIME(' || (digits -1) || ') WITH TIME ZONE')\n"
3162 : " WHEN 'decimal' THEN sys.ifthenelse(nameonly OR digits = 0, 'DECIMAL', 'DECIMAL(' || digits || sys.ifthenelse(tscale = 0, '', ',' || tscale) || ')')\n"
3163 : " WHEN 'double' THEN sys.ifthenelse(nameonly OR (digits = 53 AND tscale = 0), sys.ifthenelse(shortname, 'DOUBLE', 'DOUBLE PRECISION'), 'FLOAT(' || digits || ')')\n"
3164 : " WHEN 'real' THEN sys.ifthenelse(nameonly OR (digits = 24 AND tscale = 0), 'REAL', 'FLOAT(' || digits || ')')\n"
3165 : " WHEN 'day_interval' THEN 'INTERVAL DAY'\n"
3166 : " WHEN 'month_interval' THEN CASE digits WHEN 1 THEN 'INTERVAL YEAR' WHEN 2 THEN 'INTERVAL YEAR TO MONTH' WHEN 3 THEN 'INTERVAL MONTH' END\n"
3167 : " WHEN 'sec_interval' THEN\n"
3168 : " CASE digits\n"
3169 : " WHEN 4 THEN 'INTERVAL DAY'\n"
3170 : " WHEN 5 THEN 'INTERVAL DAY TO HOUR'\n"
3171 : " WHEN 6 THEN 'INTERVAL DAY TO MINUTE'\n"
3172 : " WHEN 7 THEN 'INTERVAL DAY TO SECOND'\n"
3173 : " WHEN 8 THEN 'INTERVAL HOUR'\n"
3174 : " WHEN 9 THEN 'INTERVAL HOUR TO MINUTE'\n"
3175 : " WHEN 10 THEN 'INTERVAL HOUR TO SECOND'\n"
3176 : " WHEN 11 THEN 'INTERVAL MINUTE'\n"
3177 : " WHEN 12 THEN 'INTERVAL MINUTE TO SECOND'\n"
3178 : " WHEN 13 THEN 'INTERVAL SECOND'\n"
3179 : " END\n"
3180 : " WHEN 'oid' THEN 'OID'\n"
3181 : " WHEN 'json' THEN sys.ifthenelse(nameonly OR digits = 0, 'JSON', 'JSON(' || digits || ')')\n"
3182 : " WHEN 'url' THEN sys.ifthenelse(nameonly OR digits = 0, 'URL', 'URL(' || digits || ')')\n"
3183 : " WHEN 'xml' THEN sys.ifthenelse(nameonly OR digits = 0, 'XML', 'XML(' || digits || ')')\n"
3184 : " WHEN 'geometry' THEN\n"
3185 : " sys.ifthenelse(nameonly, 'GEOMETRY',\n"
3186 : " CASE digits\n"
3187 : " WHEN 4 THEN 'GEOMETRY(POINT' || sys.ifthenelse(tscale = 0, ')', ',' || tscale || ')')\n"
3188 : " WHEN 8 THEN 'GEOMETRY(LINESTRING' || sys.ifthenelse(tscale = 0, ')', ',' || tscale || ')')\n"
3189 : " WHEN 16 THEN 'GEOMETRY(POLYGON' || sys.ifthenelse(tscale = 0, ')', ',' || tscale || ')')\n"
3190 : " WHEN 20 THEN 'GEOMETRY(MULTIPOINT' || sys.ifthenelse(tscale = 0, ')', ',' || tscale || ')')\n"
3191 : " WHEN 24 THEN 'GEOMETRY(MULTILINESTRING' || sys.ifthenelse(tscale = 0, ')', ',' || tscale || ')')\n"
3192 : " WHEN 28 THEN 'GEOMETRY(MULTIPOLYGON' || sys.ifthenelse(tscale = 0, ')', ',' || tscale || ')')\n"
3193 : " WHEN 32 THEN 'GEOMETRY(GEOMETRYCOLLECTION' || sys.ifthenelse(tscale = 0, ')', ',' || tscale || ')')\n"
3194 : " ELSE 'GEOMETRY'\n"
3195 : " END)\n"
3196 : " ELSE sys.ifthenelse(mtype = lower(mtype), upper(mtype), '\"' || mtype || '\"') || sys.ifthenelse(nameonly OR digits = 0, '', '(' || digits || sys.ifthenelse(tscale = 0, '', ',' || tscale) || ')')\n"
3197 : " END;\n"
3198 : "END;\n"
3199 : "GRANT EXECUTE ON FUNCTION sys.sql_datatype(varchar(999), integer, integer, boolean, boolean) TO PUBLIC;\n"
3200 : "update sys.functions set system = true where system <> true and schema_id = 2000 and name = 'sql_datatype' and type = 1 and language = 2;\n";
3201 :
3202 0 : sql->session->status = 0;
3203 0 : sql->errstr[0] = '\0';
3204 0 : printf("Running database upgrade commands:\n%s\n", cmds);
3205 0 : fflush(stdout);
3206 0 : err = SQLstatementIntern(c, cmds, "update", true, false, NULL);
3207 : }
3208 : }
3209 96 : sa_destroy(sql->sa);
3210 : }
3211 96 : sql->sa = old_sa;
3212 :
3213 :
3214 : /* 91_information_schema.sql */
3215 96 : info = mvc_bind_schema(sql, "information_schema");
3216 96 : if (info == NULL) {
3217 0 : sql->session->status = 0; /* if the schema was not found clean the error */
3218 0 : sql->errstr[0] = '\0';
3219 0 : const char cmds[] =
3220 : "CREATE SCHEMA INFORMATION_SCHEMA;\n"
3221 : "COMMENT ON SCHEMA INFORMATION_SCHEMA IS 'ISO/IEC 9075-11 SQL/Schemata';\n"
3222 : "update sys.schemas set system = true where name = 'information_schema';\n"
3223 :
3224 : "CREATE VIEW INFORMATION_SCHEMA.CHARACTER_SETS AS SELECT\n"
3225 : " cast(NULL AS varchar(1)) AS CHARACTER_SET_CATALOG,\n"
3226 : " cast(NULL AS varchar(1)) AS CHARACTER_SET_SCHEMA,\n"
3227 : " cast('UTF-8' AS varchar(16)) AS CHARACTER_SET_NAME,\n"
3228 : " cast('ISO/IEC 10646:2021' AS varchar(20)) AS CHARACTER_REPERTOIRE,\n"
3229 : " cast('UTF-8' AS varchar(16)) AS FORM_OF_USE,\n"
3230 : " cast(NULL AS varchar(1)) AS DEFAULT_COLLATE_CATALOG,\n"
3231 : " cast(NULL AS varchar(1)) AS DEFAULT_COLLATE_SCHEMA,\n"
3232 : " cast(NULL AS varchar(1)) AS DEFAULT_COLLATE_NAME;\n"
3233 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.CHARACTER_SETS TO PUBLIC WITH GRANT OPTION;\n"
3234 :
3235 : "CREATE VIEW INFORMATION_SCHEMA.SCHEMATA AS SELECT\n"
3236 : " cast(NULL AS varchar(1)) AS CATALOG_NAME,\n"
3237 : " s.\"name\" AS SCHEMA_NAME,\n"
3238 : " a.\"name\" AS SCHEMA_OWNER,\n"
3239 : " cast(NULL AS varchar(1)) AS DEFAULT_CHARACTER_SET_CATALOG,\n"
3240 : " cast(NULL AS varchar(1)) AS DEFAULT_CHARACTER_SET_SCHEMA,\n"
3241 : " cast('UTF-8' AS varchar(16)) AS DEFAULT_CHARACTER_SET_NAME,\n"
3242 : " cast(NULL AS varchar(1)) AS SQL_PATH,\n"
3243 : " s.\"id\" AS schema_id,\n"
3244 : " s.\"system\" AS is_system,\n"
3245 : " cm.\"remark\" AS comments\n"
3246 : " FROM sys.\"schemas\" s\n"
3247 : " INNER JOIN sys.\"auths\" a ON s.\"owner\" = a.\"id\"\n"
3248 : " LEFT OUTER JOIN sys.\"comments\" cm ON s.\"id\" = cm.\"id\"\n"
3249 : " ORDER BY s.\"name\";\n"
3250 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.SCHEMATA TO PUBLIC WITH GRANT OPTION;\n"
3251 :
3252 : "CREATE VIEW INFORMATION_SCHEMA.TABLES AS SELECT\n"
3253 : " cast(NULL AS varchar(1)) AS TABLE_CATALOG,\n"
3254 : " s.\"name\" AS TABLE_SCHEMA,\n"
3255 : " t.\"name\" AS TABLE_NAME,\n"
3256 : " tt.\"table_type_name\" AS TABLE_TYPE,\n"
3257 : " cast(NULL AS varchar(1)) AS SELF_REFERENCING_COLUMN_NAME,\n"
3258 : " cast(NULL AS varchar(1)) AS REFERENCE_GENERATION,\n"
3259 : " cast(NULL AS varchar(1)) AS USER_DEFINED_TYPE_CATALOG,\n"
3260 : " cast(NULL AS varchar(1)) AS USER_DEFINED_TYPE_SCHEMA,\n"
3261 : " cast(NULL AS varchar(1)) AS USER_DEFINED_TYPE_NAME,\n"
3262 : " cast(sys.ifthenelse((t.\"type\" IN (0, 3, 7, 20, 30) AND t.\"access\" IN (0, 2)), 'YES', 'NO') AS varchar(3)) AS IS_INSERTABLE_INTO,\n"
3263 : " cast('NO' AS varchar(3)) AS IS_TYPED,\n"
3264 : " cast((CASE t.\"commit_action\" WHEN 1 THEN 'DELETE' WHEN 2 THEN 'PRESERVE' WHEN 3 THEN 'DROP' ELSE NULL END) AS varchar(10)) AS COMMIT_ACTION,\n"
3265 : " t.\"schema_id\" AS schema_id,\n"
3266 : " t.\"id\" AS table_id,\n"
3267 : " t.\"type\" AS table_type_id,\n"
3268 : " st.\"count\" AS row_count,\n"
3269 : " t.\"system\" AS is_system,\n"
3270 : " sys.ifthenelse(t.\"type\" IN (1, 11), TRUE, FALSE) AS is_view,\n"
3271 : " t.\"query\" AS query_def,\n"
3272 : " cm.\"remark\" AS comments\n"
3273 : " FROM sys.\"tables\" t\n"
3274 : " INNER JOIN sys.\"schemas\" s ON t.\"schema_id\" = s.\"id\"\n"
3275 : " INNER JOIN sys.\"table_types\" tt ON t.\"type\" = tt.\"table_type_id\"\n"
3276 : " LEFT OUTER JOIN sys.\"comments\" cm ON t.\"id\" = cm.\"id\"\n"
3277 : " LEFT OUTER JOIN (SELECT DISTINCT \"schema\", \"table\", \"count\" FROM sys.\"statistics\"()) st ON (s.\"name\" = st.\"schema\" AND t.\"name\" = st.\"table\")\n"
3278 : " ORDER BY s.\"name\", t.\"name\";\n"
3279 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.TABLES TO PUBLIC WITH GRANT OPTION;\n"
3280 :
3281 : "CREATE VIEW INFORMATION_SCHEMA.VIEWS AS SELECT\n"
3282 : " cast(NULL AS varchar(1)) AS TABLE_CATALOG,\n"
3283 : " s.\"name\" AS TABLE_SCHEMA,\n"
3284 : " t.\"name\" AS TABLE_NAME,\n"
3285 : " t.\"query\" AS VIEW_DEFINITION,\n"
3286 : " cast('NONE' AS varchar(10)) AS CHECK_OPTION,\n"
3287 : " cast('NO' AS varchar(3)) AS IS_UPDATABLE,\n"
3288 : " cast('NO' AS varchar(3)) AS INSERTABLE_INTO,\n"
3289 : " cast('NO' AS varchar(3)) AS IS_TRIGGER_UPDATABLE,\n"
3290 : " cast('NO' AS varchar(3)) AS IS_TRIGGER_DELETABLE,\n"
3291 : " cast('NO' AS varchar(3)) AS IS_TRIGGER_INSERTABLE_INTO,\n"
3292 : " t.\"schema_id\" AS schema_id,\n"
3293 : " t.\"id\" AS table_id,\n"
3294 : " cast(sys.ifthenelse(t.\"system\", t.\"type\" + 10 , t.\"type\") AS smallint) AS table_type_id,\n"
3295 : " t.\"system\" AS is_system,\n"
3296 : " cm.\"remark\" AS comments\n"
3297 : " FROM sys.\"_tables\" t\n"
3298 : " INNER JOIN sys.\"schemas\" s ON t.\"schema_id\" = s.\"id\"\n"
3299 : " LEFT OUTER JOIN sys.\"comments\" cm ON t.\"id\" = cm.\"id\"\n"
3300 : " WHERE t.\"type\" = 1\n"
3301 : " ORDER BY s.\"name\", t.\"name\";\n"
3302 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.VIEWS TO PUBLIC WITH GRANT OPTION;\n"
3303 :
3304 : "CREATE VIEW INFORMATION_SCHEMA.COLUMNS AS SELECT\n"
3305 : " cast(NULL AS varchar(1)) AS TABLE_CATALOG,\n"
3306 : " s.\"name\" AS TABLE_SCHEMA,\n"
3307 : " t.\"name\" AS TABLE_NAME,\n"
3308 : " c.\"name\" AS COLUMN_NAME,\n"
3309 : " cast(1 + c.\"number\" AS int) AS ORDINAL_POSITION,\n"
3310 : " c.\"default\" AS COLUMN_DEFAULT,\n"
3311 : " cast(sys.ifthenelse(c.\"null\", 'YES', 'NO') AS varchar(3)) AS IS_NULLABLE,\n"
3312 : " cast(sys.\"sql_datatype\"(c.\"type\", c.\"type_digits\", c.\"type_scale\", true, true) AS varchar(1024)) AS DATA_TYPE,\n"
3313 : " cast(sys.ifthenelse(c.\"type\" IN ('varchar','clob','char','json','url','xml') AND c.\"type_digits\" > 0, c.\"type_digits\", NULL) AS int) AS CHARACTER_MAXIMUM_LENGTH,\n"
3314 : " cast(sys.ifthenelse(c.\"type\" IN ('varchar','clob','char','json','url','xml') AND c.\"type_digits\" > 0, 4 * cast(c.\"type_digits\" as bigint), NULL) AS bigint) AS CHARACTER_OCTET_LENGTH,\n"
3315 : " cast(sys.ifthenelse(c.\"type\" IN ('int','smallint','tinyint','bigint','hugeint','float','real','double','decimal','numeric','oid'), c.\"type_digits\", NULL) AS int) AS NUMERIC_PRECISION,\n"
3316 : " cast(sys.ifthenelse(c.\"type\" IN ('int','smallint','tinyint','bigint','hugeint','float','real','double','oid'), 2, sys.ifthenelse(c.\"type\" IN ('decimal','numeric'), 10, NULL)) AS int) AS NUMERIC_PRECISION_RADIX,\n"
3317 : " cast(sys.ifthenelse(c.\"type\" IN ('int','smallint','tinyint','bigint','hugeint','float','real','double','decimal','numeric','oid'), c.\"type_scale\", NULL) AS int) AS NUMERIC_SCALE,\n"
3318 : " cast(sys.ifthenelse(c.\"type\" IN ('date','timestamp','timestamptz','time','timetz'), sys.ifthenelse(c.\"type_scale\" > 0, c.\"type_scale\" -1, 0), NULL) AS int) AS DATETIME_PRECISION,\n"
3319 : " cast(sys.ifthenelse(c.\"type\" IN ('day_interval','month_interval','sec_interval'), sys.\"sql_datatype\"(c.\"type\", c.\"type_digits\", c.\"type_scale\", true, true), NULL) AS varchar(40)) AS INTERVAL_TYPE,\n"
3320 : " cast(CASE c.\"type\" WHEN 'day_interval' THEN 0 WHEN 'month_interval' THEN 0 WHEN 'sec_interval' THEN (sys.ifthenelse(c.\"type_digits\" IN (7, 10, 12, 13), sys.ifthenelse(c.\"type_scale\" > 0, c.\"type_scale\", 3), 0)) ELSE NULL END AS int) AS INTERVAL_PRECISION,\n"
3321 : " cast(NULL AS varchar(1)) AS CHARACTER_SET_CATALOG,\n"
3322 : " cast(NULL AS varchar(1)) AS CHARACTER_SET_SCHEMA,\n"
3323 : " cast(sys.ifthenelse(c.\"type\" IN ('varchar','clob','char','json','url','xml'), 'UTF-8', NULL) AS varchar(16)) AS CHARACTER_SET_NAME,\n"
3324 : " cast(NULL AS varchar(1)) AS COLLATION_CATALOG,\n"
3325 : " cast(NULL AS varchar(1)) AS COLLATION_SCHEMA,\n"
3326 : " cast(NULL AS varchar(1)) AS COLLATION_NAME,\n"
3327 : " cast(NULL AS varchar(1)) AS DOMAIN_CATALOG,\n"
3328 : " cast(NULL AS varchar(1)) AS DOMAIN_SCHEMA,\n"
3329 : " cast(NULL AS varchar(1)) AS DOMAIN_NAME,\n"
3330 : " cast(NULL AS varchar(1)) AS UDT_CATALOG,\n"
3331 : " cast(NULL AS varchar(1)) AS UDT_SCHEMA,\n"
3332 : " cast(NULL AS varchar(1)) AS UDT_NAME,\n"
3333 : " cast(NULL AS varchar(1)) AS SCOPE_CATALOG,\n"
3334 : " cast(NULL AS varchar(1)) AS SCOPE_SCHEMA,\n"
3335 : " cast(NULL AS varchar(1)) AS SCOPE_NAME,\n"
3336 : " cast(NULL AS int) AS MAXIMUM_CARDINALITY,\n"
3337 : " cast(NULL AS varchar(1)) AS DTD_IDENTIFIER,\n"
3338 : " cast('NO' AS varchar(3)) AS IS_SELF_REFERENCING,\n"
3339 : " cast(sys.ifthenelse(seq.\"name\" IS NULL OR c.\"null\", 'NO', 'YES') AS varchar(3)) AS IS_IDENTITY,\n"
3340 : " seq.\"name\" AS IDENTITY_GENERATION,\n"
3341 : " seq.\"start\" AS IDENTITY_START,\n"
3342 : " seq.\"increment\" AS IDENTITY_INCREMENT,\n"
3343 : " seq.\"maxvalue\" AS IDENTITY_MAXIMUM,\n"
3344 : " seq.\"minvalue\" AS IDENTITY_MINIMUM,\n"
3345 : " cast(sys.ifthenelse(seq.\"name\" IS NULL, NULL, sys.ifthenelse(seq.\"cycle\", 'YES', 'NO')) AS varchar(3)) AS IDENTITY_CYCLE,\n"
3346 : " cast(sys.ifthenelse(seq.\"name\" IS NULL, 'NO', 'YES') AS varchar(3)) AS IS_GENERATED,\n"
3347 : " cast(sys.ifthenelse(seq.\"name\" IS NULL, NULL, c.\"default\") AS varchar(1024)) AS GENERATION_EXPRESSION,\n"
3348 : " cast('NO' AS varchar(3)) AS IS_SYSTEM_TIME_PERIOD_START,\n"
3349 : " cast('NO' AS varchar(3)) AS IS_SYSTEM_TIME_PERIOD_END,\n"
3350 : " cast('NO' AS varchar(3)) AS SYSTEM_TIME_PERIOD_TIMESTAMP_GENERATION,\n"
3351 : " cast(sys.ifthenelse(t.\"type\" IN (0,3,7,20,30), 'YES', 'NO') AS varchar(3)) AS IS_UPDATABLE,\n"
3352 : " cast(NULL AS varchar(1)) AS DECLARED_DATA_TYPE,\n"
3353 : " cast(NULL AS int) AS DECLARED_NUMERIC_PRECISION,\n"
3354 : " cast(NULL AS int) AS DECLARED_NUMERIC_SCALE,\n"
3355 : " t.\"schema_id\" AS schema_id,\n"
3356 : " c.\"table_id\" AS table_id,\n"
3357 : " c.\"id\" AS column_id,\n"
3358 : " seq.\"id\" AS sequence_id,\n"
3359 : " t.\"system\" AS is_system,\n"
3360 : " cm.\"remark\" AS comments\n"
3361 : " FROM sys.\"columns\" c\n"
3362 : " INNER JOIN sys.\"tables\" t ON c.\"table_id\" = t.\"id\"\n"
3363 : " INNER JOIN sys.\"schemas\" s ON t.\"schema_id\" = s.\"id\"\n"
3364 : " LEFT OUTER JOIN sys.\"comments\" cm ON c.\"id\" = cm.\"id\"\n"
3365 : " LEFT OUTER JOIN sys.\"sequences\" seq ON ((seq.\"name\"||'\"') = substring(c.\"default\", 3 + sys.\"locate\"('\".\"seq_',c.\"default\",14)))\n"
3366 : " ORDER BY s.\"name\", t.\"name\", c.\"number\";\n"
3367 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.COLUMNS TO PUBLIC WITH GRANT OPTION;\n"
3368 :
3369 : "CREATE VIEW INFORMATION_SCHEMA.CHECK_CONSTRAINTS AS SELECT\n"
3370 : " cast(NULL AS varchar(1)) AS CONSTRAINT_CATALOG,\n"
3371 : " cast(NULL AS varchar(1024)) AS CONSTRAINT_SCHEMA,\n"
3372 : " cast(NULL AS varchar(1024)) AS CONSTRAINT_NAME,\n"
3373 : " cast(NULL AS varchar(1024)) AS CHECK_CLAUSE\n"
3374 : " WHERE 1=0;\n"
3375 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.CHECK_CONSTRAINTS TO PUBLIC WITH GRANT OPTION;\n"
3376 :
3377 : "CREATE VIEW INFORMATION_SCHEMA.TABLE_CONSTRAINTS AS SELECT\n"
3378 : " cast(NULL AS varchar(1)) AS CONSTRAINT_CATALOG,\n"
3379 : " s.\"name\" AS CONSTRAINT_SCHEMA,\n"
3380 : " k.\"name\" AS CONSTRAINT_NAME,\n"
3381 : " cast(NULL AS varchar(1)) AS TABLE_CATALOG,\n"
3382 : " s.\"name\" AS TABLE_SCHEMA,\n"
3383 : " t.\"name\" AS TABLE_NAME,\n"
3384 : " cast(CASE k.\"type\" WHEN 0 THEN 'PRIMARY KEY' WHEN 1 THEN 'UNIQUE' WHEN 2 THEN 'FOREIGN KEY' ELSE NULL END AS varchar(16)) AS CONSTRAINT_TYPE,\n"
3385 : " cast('NO' AS varchar(3)) AS IS_DEFERRABLE,\n"
3386 : " cast('NO' AS varchar(3)) AS INITIALLY_DEFERRED,\n"
3387 : " cast('YES' AS varchar(3)) AS ENFORCED,\n"
3388 : " t.\"schema_id\" AS schema_id,\n"
3389 : " t.\"id\" AS table_id,\n"
3390 : " k.\"id\" AS key_id,\n"
3391 : " k.\"type\" AS key_type,\n"
3392 : " t.\"system\" AS is_system\n"
3393 : " FROM (SELECT sk.\"id\", sk.\"table_id\", sk.\"name\", sk.\"type\" FROM sys.\"keys\" sk UNION ALL SELECT tk.\"id\", tk.\"table_id\", tk.\"name\", tk.\"type\" FROM tmp.\"keys\" tk) k\n"
3394 : " INNER JOIN (SELECT st.\"id\", st.\"schema_id\", st.\"name\", st.\"system\" FROM sys.\"_tables\" st UNION ALL"
3395 : " SELECT tt.\"id\", tt.\"schema_id\", tt.\"name\", tt.\"system\" FROM tmp.\"_tables\" tt) t ON k.\"table_id\" = t.\"id\"\n"
3396 : " INNER JOIN sys.\"schemas\" s ON t.\"schema_id\" = s.\"id\"\n"
3397 : " ORDER BY s.\"name\", t.\"name\", k.\"name\";\n"
3398 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.TABLE_CONSTRAINTS TO PUBLIC WITH GRANT OPTION;\n"
3399 :
3400 : "CREATE VIEW INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS AS SELECT\n"
3401 : " cast(NULL AS varchar(1)) AS CONSTRAINT_CATALOG,\n"
3402 : " s.\"name\" AS CONSTRAINT_SCHEMA,\n"
3403 : " fk.\"name\" AS CONSTRAINT_NAME,\n"
3404 : " cast(NULL AS varchar(1)) AS UNIQUE_CONSTRAINT_CATALOG,\n"
3405 : " uks.\"name\" AS UNIQUE_CONSTRAINT_SCHEMA,\n"
3406 : " uk.\"name\" AS UNIQUE_CONSTRAINT_NAME,\n"
3407 : " cast('FULL' AS varchar(7)) AS MATCH_OPTION,\n"
3408 : " fk.\"update_action\" AS UPDATE_RULE,\n"
3409 : " fk.\"delete_action\" AS DELETE_RULE,\n"
3410 : " t.\"schema_id\" AS fk_schema_id,\n"
3411 : " t.\"id\" AS fk_table_id,\n"
3412 : " t.\"name\" AS fk_table_name,\n"
3413 : " fk.\"id\" AS fk_key_id,\n"
3414 : " ukt.\"schema_id\" AS uc_schema_id,\n"
3415 : " uk.\"table_id\" AS uc_table_id,\n"
3416 : " ukt.\"name\" AS uc_table_name,\n"
3417 : " uk.\"id\" AS uc_key_id\n"
3418 : " FROM sys.\"fkeys\" fk\n"
3419 : " INNER JOIN sys.\"tables\" t ON t.\"id\" = fk.\"table_id\"\n"
3420 : " INNER JOIN sys.\"schemas\" s ON s.\"id\" = t.\"schema_id\"\n"
3421 : " LEFT OUTER JOIN sys.\"keys\" uk ON uk.\"id\" = fk.\"rkey\"\n"
3422 : " LEFT OUTER JOIN sys.\"tables\" ukt ON ukt.\"id\" = uk.\"table_id\"\n"
3423 : " LEFT OUTER JOIN sys.\"schemas\" uks ON uks.\"id\" = ukt.\"schema_id\"\n"
3424 : " ORDER BY s.\"name\", t.\"name\", fk.\"name\";\n"
3425 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS TO PUBLIC WITH GRANT OPTION;\n"
3426 :
3427 : "CREATE VIEW INFORMATION_SCHEMA.ROUTINES AS SELECT\n"
3428 : " cast(NULL AS varchar(1)) AS SPECIFIC_CATALOG,\n"
3429 : " s.\"name\" AS SPECIFIC_SCHEMA,\n"
3430 : " cast(f.\"name\"||'('||f.\"id\"||')' AS varchar(270)) AS SPECIFIC_NAME,\n"
3431 : " cast(NULL AS varchar(1)) AS ROUTINE_CATALOG,\n"
3432 : " s.\"name\" AS ROUTINE_SCHEMA,\n"
3433 : " f.\"name\" AS ROUTINE_NAME,\n"
3434 : " ft.\"function_type_keyword\" AS ROUTINE_TYPE,\n"
3435 : " cast(NULL AS varchar(1)) AS MODULE_CATALOG,\n"
3436 : " cast(NULL AS varchar(1)) AS MODULE_SCHEMA,\n"
3437 : " cast(f.\"mod\" AS varchar(128)) AS MODULE_NAME,\n"
3438 : " cast(NULL AS varchar(1)) AS UDT_CATALOG,\n"
3439 : " cast(NULL AS varchar(1)) AS UDT_SCHEMA,\n"
3440 : " cast(NULL AS varchar(1)) AS UDT_NAME,\n"
3441 : " cast(CASE f.\"type\" WHEN 1 THEN sys.\"sql_datatype\"(a.\"type\", a.\"type_digits\", a.\"type_scale\", true, true) WHEN 2 THEN NULL WHEN 5 THEN 'TABLE' WHEN 7 THEN 'TABLE' ELSE NULL END AS varchar(1024)) AS DATA_TYPE,\n"
3442 : " cast(sys.ifthenelse(a.\"type\" IN ('varchar','clob','char','json','url','xml') AND a.\"type_digits\" > 0, a.\"type_digits\", NULL) AS int) AS CHARACTER_MAXIMUM_LENGTH,\n"
3443 : " cast(sys.ifthenelse(a.\"type\" IN ('varchar','clob','char','json','url','xml') AND a.\"type_digits\" > 0, 4 * cast(a.\"type_digits\" as bigint), NULL) AS bigint) AS CHARACTER_OCTET_LENGTH,\n"
3444 : " cast(NULL AS varchar(1)) AS CHARACTER_SET_CATALOG,\n"
3445 : " cast(NULL AS varchar(1)) AS CHARACTER_SET_SCHEMA,\n"
3446 : " 'UTF-8' AS CHARACTER_SET_NAME,\n"
3447 : " cast(NULL AS varchar(1)) AS COLLATION_CATALOG,\n"
3448 : " cast(NULL AS varchar(1)) AS COLLATION_SCHEMA,\n"
3449 : " cast(NULL AS varchar(1)) AS COLLATION_NAME,\n"
3450 : " cast(sys.ifthenelse(a.\"type\" IN ('int','smallint','tinyint','bigint','hugeint','float','real','double','decimal','numeric','oid'), a.\"type_digits\", NULL) AS int) AS NUMERIC_PRECISION,\n"
3451 : " cast(sys.ifthenelse(a.\"type\" IN ('int','smallint','tinyint','bigint','hugeint','float','real','double','oid'), 2, sys.ifthenelse(a.\"type\" IN ('decimal','numeric'), 10, NULL)) AS int) AS NUMERIC_PRECISION_RADIX,\n"
3452 : " cast(sys.ifthenelse(a.\"type\" IN ('int','smallint','tinyint','bigint','hugeint','float','real','double','decimal','numeric','oid'), a.\"type_scale\", NULL) AS int) AS NUMERIC_SCALE,\n"
3453 : " cast(sys.ifthenelse(a.\"type\" IN ('date','timestamp','timestamptz','time','timetz'), a.\"type_scale\" -1, NULL) AS int) AS DATETIME_PRECISION,\n"
3454 : " cast(sys.ifthenelse(a.\"type\" IN ('day_interval','month_interval','sec_interval'), sys.\"sql_datatype\"(a.\"type\", a.\"type_digits\", a.\"type_scale\", true, true), NULL) AS varchar(40)) AS INTERVAL_TYPE,\n"
3455 : " cast(CASE a.\"type\" WHEN 'day_interval' THEN 0 WHEN 'month_interval' THEN 0 WHEN 'sec_interval' THEN (sys.ifthenelse(a.\"type_digits\" IN (7, 10, 12, 13), sys.ifthenelse(a.\"type_scale\" > 0, a.\"type_scale\", 3), 0)) ELSE NULL END AS int) AS INTERVAL_PRECISION,\n"
3456 : " cast(NULL AS varchar(1)) AS TYPE_UDT_CATALOG,\n"
3457 : " cast(NULL AS varchar(1)) AS TYPE_UDT_SCHEMA,\n"
3458 : " cast(NULL AS varchar(1)) AS TYPE_UDT_NAME,\n"
3459 : " cast(NULL AS varchar(1)) AS SCOPE_CATALOG,\n"
3460 : " cast(NULL AS varchar(1)) AS SCOPE_SCHEMA,\n"
3461 : " cast(NULL AS varchar(1)) AS SCOPE_NAME,\n"
3462 : " cast(NULL AS int) AS MAXIMUM_CARDINALITY,\n"
3463 : " cast(NULL AS int) AS DTD_IDENTIFIER,\n"
3464 : " cast(sys.\"ifthenelse\"(sys.\"locate\"('begin',f.\"func\") > 0, sys.\"ifthenelse\"(sys.\"endswith\"(f.\"func\",';'), sys.\"substring\"(f.\"func\", sys.\"locate\"('begin',f.\"func\"), sys.\"length\"(sys.\"substring\"(f.\"func\", sys.\"locate\"('begin',f.\"func\")))-1), sys.\"substring\"(f.\"func\", sys.\"locate\"('begin',f.\"func\"))), NULL) AS varchar(8196)) AS ROUTINE_BODY,\n"
3465 : " f.\"func\" AS ROUTINE_DEFINITION,\n"
3466 : " cast(sys.\"ifthenelse\"(sys.\"locate\"('external name',f.\"func\") > 0, sys.\"ifthenelse\"(sys.\"endswith\"(f.\"func\",';'), sys.\"substring\"(f.\"func\", 14 + sys.\"locate\"('external name',f.\"func\"), sys.\"length\"(sys.\"substring\"(f.\"func\", 14 + sys.\"locate\"('external name',f.\"func\")))-1), sys.\"substring\"(f.\"func\", 14 + sys.\"locate\"('external name',f.\"func\"))), NULL) AS varchar(1024)) AS EXTERNAL_NAME,\n"
3467 : " fl.\"language_keyword\" AS EXTERNAL_LANGUAGE,\n"
3468 : " 'GENERAL' AS PARAMETER_STYLE,\n"
3469 : " 'YES' AS IS_DETERMINISTIC,\n"
3470 : " cast(sys.ifthenelse(f.\"side_effect\", 'MODIFIES', 'READ') AS varchar(10)) AS SQL_DATA_ACCESS,\n"
3471 : " cast(CASE f.\"type\" WHEN 2 THEN NULL ELSE 'NO' END AS varchar(3)) AS IS_NULL_CALL,\n"
3472 : " cast(NULL AS varchar(1)) AS SQL_PATH,\n"
3473 : " cast(NULL AS varchar(1)) AS SCHEMA_LEVEL_ROUTINE,\n"
3474 : " cast(NULL AS int) AS MAX_DYNAMIC_RESULT_SETS,\n"
3475 : " cast(NULL AS varchar(1)) AS IS_USER_DEFINED_CAST,\n"
3476 : " cast(NULL AS varchar(1)) AS IS_IMPLICITLY_INVOCABLE,\n"
3477 : " cast(NULL AS varchar(1)) AS SECURITY_TYPE,\n"
3478 : " cast(NULL AS varchar(1)) AS TO_SQL_SPECIFIC_CATALOG,\n"
3479 : " cast(NULL AS varchar(1)) AS TO_SQL_SPECIFIC_SCHEMA,\n"
3480 : " cast(NULL AS varchar(1)) AS TO_SQL_SPECIFIC_NAME,\n"
3481 : " cast(NULL AS varchar(1)) AS AS_LOCATOR,\n"
3482 : " cast(NULL AS timestamp) AS CREATED,\n"
3483 : " cast(NULL AS timestamp) AS LAST_ALTERED,\n"
3484 : " cast(NULL AS varchar(1)) AS NEW_SAVEPOINT_LEVEL,\n"
3485 : " cast(NULL AS varchar(1)) AS IS_UDT_DEPENDENT,\n"
3486 : " cast(NULL AS varchar(1)) AS RESULT_CAST_FROM_DATA_TYPE,\n"
3487 : " cast(NULL AS varchar(1)) AS RESULT_CAST_AS_LOCATOR,\n"
3488 : " cast(NULL AS int) AS RESULT_CAST_CHAR_MAX_LENGTH,\n"
3489 : " cast(NULL AS int) AS RESULT_CAST_CHAR_OCTET_LENGTH,\n"
3490 : " cast(NULL AS varchar(1)) AS RESULT_CAST_CHAR_SET_CATALOG,\n"
3491 : " cast(NULL AS varchar(1)) AS RESULT_CAST_CHAR_SET_SCHEMA,\n"
3492 : " cast(NULL AS varchar(1)) AS RESULT_CAST_CHARACTER_SET_NAME,\n"
3493 : " cast(NULL AS varchar(1)) AS RESULT_CAST_COLLATION_CATALOG,\n"
3494 : " cast(NULL AS varchar(1)) AS RESULT_CAST_COLLATION_SCHEMA,\n"
3495 : " cast(NULL AS varchar(1)) AS RESULT_CAST_COLLATION_NAME,\n"
3496 : " cast(NULL AS int) AS RESULT_CAST_NUMERIC_PRECISION,\n"
3497 : " cast(NULL AS int) AS RESULT_CAST_NUMERIC_RADIX,\n"
3498 : " cast(NULL AS int) AS RESULT_CAST_NUMERIC_SCALE,\n"
3499 : " cast(NULL AS int) AS RESULT_CAST_DATETIME_PRECISION,\n"
3500 : " cast(NULL AS varchar(1)) AS RESULT_CAST_INTERVAL_TYPE,\n"
3501 : " cast(NULL AS int) AS RESULT_CAST_INTERVAL_PRECISION,\n"
3502 : " cast(NULL AS varchar(1)) AS RESULT_CAST_TYPE_UDT_CATALOG,\n"
3503 : " cast(NULL AS varchar(1)) AS RESULT_CAST_TYPE_UDT_SCHEMA,\n"
3504 : " cast(NULL AS varchar(1)) AS RESULT_CAST_TYPE_UDT_NAME,\n"
3505 : " cast(NULL AS varchar(1)) AS RESULT_CAST_SCOPE_CATALOG,\n"
3506 : " cast(NULL AS varchar(1)) AS RESULT_CAST_SCOPE_SCHEMA,\n"
3507 : " cast(NULL AS varchar(1)) AS RESULT_CAST_SCOPE_NAME,\n"
3508 : " cast(NULL AS int) AS RESULT_CAST_MAX_CARDINALITY,\n"
3509 : " cast(NULL AS varchar(1)) AS RESULT_CAST_DTD_IDENTIFIER,\n"
3510 : " cast(NULL AS varchar(1)) AS DECLARED_DATA_TYPE,\n"
3511 : " cast(NULL AS int) AS DECLARED_NUMERIC_PRECISION,\n"
3512 : " cast(NULL AS int) AS DECLARED_NUMERIC_SCALE,\n"
3513 : " cast(NULL AS varchar(1)) AS RESULT_CAST_FROM_DECLARED_DATA_TYPE,\n"
3514 : " cast(NULL AS int) AS RESULT_CAST_DECLARED_NUMERIC_PRECISION,\n"
3515 : " cast(NULL AS int) AS RESULT_CAST_DECLARED_NUMERIC_SCALE,\n"
3516 : " f.\"schema_id\" AS schema_id,\n"
3517 : " f.\"id\" AS function_id,\n"
3518 : " f.\"type\" AS function_type,\n"
3519 : " f.\"language\" AS function_language,\n"
3520 : " f.\"system\" AS is_system,\n"
3521 : " cm.\"remark\" AS comments\n"
3522 : " FROM sys.\"functions\" f\n"
3523 : " INNER JOIN sys.\"schemas\" s ON s.\"id\" = f.\"schema_id\"\n"
3524 : " INNER JOIN sys.\"function_types\" ft ON ft.\"function_type_id\" = f.\"type\"\n"
3525 : " INNER JOIN sys.\"function_languages\" fl ON fl.\"language_id\" = f.\"language\"\n"
3526 : " LEFT OUTER JOIN sys.\"args\" a ON a.\"func_id\" = f.\"id\" and a.\"inout\" = 0 and a.\"number\" = 0\n"
3527 : " LEFT OUTER JOIN sys.\"comments\" cm ON cm.\"id\" = f.\"id\"\n"
3528 : " WHERE f.\"type\" in (1, 2, 5, 7)\n"
3529 : " ORDER BY s.\"name\", f.\"name\";\n"
3530 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.ROUTINES TO PUBLIC WITH GRANT OPTION;\n"
3531 :
3532 : "CREATE VIEW INFORMATION_SCHEMA.PARAMETERS AS SELECT\n"
3533 : " cast(NULL AS varchar(1)) AS SPECIFIC_CATALOG,\n"
3534 : " s.\"name\" AS SPECIFIC_SCHEMA,\n"
3535 : " cast(f.\"name\"||'('||f.\"id\"||')' AS varchar(270)) AS SPECIFIC_NAME,\n"
3536 : " cast(sys.ifthenelse((a.\"inout\" = 0 OR f.\"type\" = 2), 1 + a.\"number\", sys.ifthenelse(f.\"type\" = 1, a.\"number\", (1 + a.\"number\" - f.count_out_cols))) AS int) AS ORDINAL_POSITION,\n"
3537 : " cast(sys.ifthenelse(a.\"inout\" = 0, 'OUT', sys.ifthenelse(a.\"inout\" = 1, 'IN', 'INOUT')) as varchar(5)) AS PARAMETER_MODE,\n"
3538 : " cast(sys.ifthenelse(a.\"inout\" = 0, 'YES', 'NO') as varchar(3)) AS IS_RESULT,\n"
3539 : " cast(NULL AS varchar(1)) AS AS_LOCATOR,\n"
3540 : " a.\"name\" AS PARAMETER_NAME,\n"
3541 : " cast(NULL AS varchar(1)) AS FROM_SQL_SPECIFIC_CATALOG,\n"
3542 : " cast(NULL AS varchar(1)) AS FROM_SQL_SPECIFIC_SCHEMA,\n"
3543 : " cast(NULL AS varchar(1)) AS FROM_SQL_SPECIFIC_NAME,\n"
3544 : " cast(NULL AS varchar(1)) AS TO_SQL_SPECIFIC_CATALOG,\n"
3545 : " cast(NULL AS varchar(1)) AS TO_SQL_SPECIFIC_SCHEMA,\n"
3546 : " cast(NULL AS varchar(1)) AS TO_SQL_SPECIFIC_NAME,\n"
3547 : " cast(sys.\"sql_datatype\"(a.\"type\", a.\"type_digits\", a.\"type_scale\", true, true) AS varchar(1024)) AS DATA_TYPE,\n"
3548 : " cast(sys.ifthenelse(a.\"type\" IN ('varchar','clob','char','json','url','xml') AND a.\"type_digits\" > 0, a.\"type_digits\", NULL) AS int) AS CHARACTER_MAXIMUM_LENGTH,\n"
3549 : " cast(sys.ifthenelse(a.\"type\" IN ('varchar','clob','char','json','url','xml') AND a.\"type_digits\" > 0, 4 * cast(a.\"type_digits\" as bigint), NULL) AS bigint) AS CHARACTER_OCTET_LENGTH,\n"
3550 : " cast(NULL AS varchar(1)) AS CHARACTER_SET_CATALOG,\n"
3551 : " cast(NULL AS varchar(1)) AS CHARACTER_SET_SCHEMA,\n"
3552 : " cast(sys.ifthenelse(a.\"type\" IN ('varchar','clob','char','json','url','xml'), 'UTF-8', NULL) AS varchar(16)) AS CHARACTER_SET_NAME,\n"
3553 : " cast(NULL AS varchar(1)) AS COLLATION_CATALOG,\n"
3554 : " cast(NULL AS varchar(1)) AS COLLATION_SCHEMA,\n"
3555 : " cast(NULL AS varchar(1)) AS COLLATION_NAME,\n"
3556 : " cast(sys.ifthenelse(a.\"type\" IN ('int','smallint','tinyint','bigint','hugeint','float','real','double','decimal','numeric','oid'), a.\"type_digits\", NULL) AS int) AS NUMERIC_PRECISION,\n"
3557 : " cast(sys.ifthenelse(a.\"type\" IN ('int','smallint','tinyint','bigint','hugeint','float','real','double','oid'), 2, sys.ifthenelse(a.\"type\" IN ('decimal','numeric'), 10, NULL)) AS int) AS NUMERIC_PRECISION_RADIX,\n"
3558 : " cast(sys.ifthenelse(a.\"type\" IN ('int','smallint','tinyint','bigint','hugeint','float','real','double','decimal','numeric','oid'), a.\"type_scale\", NULL) AS int) AS NUMERIC_SCALE,\n"
3559 : " cast(sys.ifthenelse(a.\"type\" IN ('date','timestamp','timestamptz','time','timetz'), sys.ifthenelse(a.\"type_scale\" > 0, a.\"type_scale\" -1, 0), NULL) AS int) AS DATETIME_PRECISION,\n"
3560 : " cast(sys.ifthenelse(a.\"type\" IN ('day_interval','month_interval','sec_interval'), sys.\"sql_datatype\"(a.\"type\", a.\"type_digits\", a.\"type_scale\", true, true), NULL) AS varchar(40)) AS INTERVAL_TYPE,\n"
3561 : " cast(CASE a.\"type\" WHEN 'day_interval' THEN 0 WHEN 'month_interval' THEN 0 WHEN 'sec_interval' THEN (sys.ifthenelse(a.\"type_digits\" IN (7, 10, 12, 13), sys.ifthenelse(a.\"type_scale\" > 0, a.\"type_scale\", 3), 0)) ELSE NULL END AS int) AS INTERVAL_PRECISION,\n"
3562 : " cast(NULL AS varchar(1)) AS UDT_CATALOG,\n"
3563 : " cast(NULL AS varchar(1)) AS UDT_SCHEMA,\n"
3564 : " cast(NULL AS varchar(1)) AS UDT_NAME,\n"
3565 : " cast(NULL AS varchar(1)) AS SCOPE_CATALOG,\n"
3566 : " cast(NULL AS varchar(1)) AS SCOPE_SCHEMA,\n"
3567 : " cast(NULL AS varchar(1)) AS SCOPE_NAME,\n"
3568 : " cast(NULL AS int) AS MAXIMUM_CARDINALITY,\n"
3569 : " cast(NULL AS varchar(1)) AS DTD_IDENTIFIER,\n"
3570 : " cast(NULL AS varchar(1)) AS DECLARED_DATA_TYPE,\n"
3571 : " cast(NULL AS int) AS DECLARED_NUMERIC_PRECISION,\n"
3572 : " cast(NULL AS int) AS DECLARED_NUMERIC_SCALE,\n"
3573 : " cast(NULL AS varchar(1)) AS PARAMETER_DEFAULT,\n"
3574 : " f.\"schema_id\" AS schema_id,\n"
3575 : " f.\"id\" AS function_id,\n"
3576 : " a.\"id\" AS arg_id,\n"
3577 : " f.\"name\" AS function_name,\n"
3578 : " f.\"type\" AS function_type,\n"
3579 : " f.\"system\" AS is_system\n"
3580 : " FROM sys.\"args\" a\n"
3581 : " INNER JOIN (SELECT fun.*, (select count(*) from sys.args a0 where a0.inout = 0 and a0.func_id = fun.id) as count_out_cols FROM sys.\"functions\" fun WHERE fun.\"type\" in (1, 2, 5, 7)) f ON f.\"id\" = a.\"func_id\"\n"
3582 : " INNER JOIN sys.\"schemas\" s ON s.\"id\" = f.\"schema_id\"\n"
3583 : " ORDER BY s.\"name\", f.\"name\", f.\"id\", a.\"inout\" DESC, a.\"number\";\n"
3584 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.PARAMETERS TO PUBLIC WITH GRANT OPTION;\n"
3585 :
3586 : "CREATE VIEW INFORMATION_SCHEMA.SEQUENCES AS SELECT\n"
3587 : " cast(NULL AS varchar(1)) AS SEQUENCE_CATALOG,\n"
3588 : " s.\"name\" AS SEQUENCE_SCHEMA,\n"
3589 : " sq.\"name\" AS SEQUENCE_NAME,\n"
3590 : " cast('BIGINT' AS varchar(16)) AS DATA_TYPE,\n"
3591 : " cast(64 AS SMALLINT) AS NUMERIC_PRECISION,\n"
3592 : " cast(2 AS SMALLINT) AS NUMERIC_PRECISION_RADIX,\n"
3593 : " cast(0 AS SMALLINT) AS NUMERIC_SCALE,\n"
3594 : " sq.\"start\" AS START_VALUE,\n"
3595 : " sq.\"minvalue\" AS MINIMUM_VALUE,\n"
3596 : " sq.\"maxvalue\" AS MAXIMUM_VALUE,\n"
3597 : " sq.\"increment\" AS INCREMENT,\n"
3598 : " cast(sys.ifthenelse(sq.\"cycle\", 'YES', 'NO') AS varchar(3)) AS CYCLE_OPTION,\n"
3599 : " cast(NULL AS varchar(16)) AS DECLARED_DATA_TYPE,\n"
3600 : " cast(NULL AS SMALLINT) AS DECLARED_NUMERIC_PRECISION,\n"
3601 : " cast(NULL AS SMALLINT) AS DECLARED_NUMERIC_SCALE,\n"
3602 : " sq.\"schema_id\" AS schema_id,\n"
3603 : " sq.\"id\" AS sequence_id,\n"
3604 : " get_value_for(s.\"name\", sq.\"name\") AS current_value,\n"
3605 : " sq.\"cacheinc\" AS cacheinc,\n"
3606 : " cm.\"remark\" AS comments\n"
3607 : " FROM sys.\"sequences\" sq\n"
3608 : " INNER JOIN sys.\"schemas\" s ON sq.\"schema_id\" = s.\"id\"\n"
3609 : " LEFT OUTER JOIN sys.\"comments\" cm ON sq.\"id\" = cm.\"id\"\n"
3610 : " ORDER BY s.\"name\", sq.\"name\";\n"
3611 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.SEQUENCES TO PUBLIC WITH GRANT OPTION;\n"
3612 : "\n"
3613 : "update sys._tables set system = true where system <> true\n"
3614 : " and schema_id = (select s.id from sys.schemas s where s.name = 'information_schema')\n"
3615 : " and name in ('character_sets','check_constraints','columns','parameters','routines','schemata','sequences','referential_constraints','table_constraints','tables','views');\n";
3616 0 : printf("Running database upgrade commands:\n%s\n", cmds);
3617 0 : fflush(stdout);
3618 0 : err = SQLstatementIntern(c, cmds, "update", true, false, NULL);
3619 : }
3620 :
3621 : /* 77_storage.sql */
3622 96 : sql_find_subtype(&tp, "varchar", 0, 0);
3623 :
3624 96 : if (!sql_bind_func(sql, s->base.name, "persist_unlogged", &tp, &tp, F_UNION, true, true)) {
3625 0 : sql->session->status = 0;
3626 0 : sql->errstr[0] = '\0';
3627 0 : const char query[] =
3628 : "CREATE FUNCTION sys.persist_unlogged(sname STRING, tname STRING)\n"
3629 : "RETURNS TABLE(\"table\" STRING, \"table_id\" INT, \"rowcount\" BIGINT)\n"
3630 : "EXTERNAL NAME sql.persist_unlogged;\n"
3631 : "GRANT EXECUTE ON FUNCTION sys.persist_unlogged(string, string) TO PUBLIC;\n"
3632 : "UPDATE sys.functions SET system = true WHERE system <> true AND\n"
3633 : "name = 'persist_unlogged' AND schema_id = 2000 AND type = 5 AND language = 1;\n";
3634 0 : printf("Running database upgrade commands:\n%s\n", query);
3635 0 : fflush(stdout);
3636 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
3637 : }
3638 :
3639 96 : return err;
3640 : }
3641 :
3642 : static str
3643 96 : sql_update_dec2023_sp1(Client c, mvc *sql, sql_schema *s)
3644 : {
3645 96 : char *err;
3646 96 : res_table *output;
3647 96 : BAT *b;
3648 :
3649 96 : (void) sql;
3650 96 : (void) s;
3651 :
3652 : /* json.isvalid(json) has been fixed to return NULL on NULL input */
3653 96 : err = SQLstatementIntern(c, "SELECT f.id FROM sys.functions f WHERE f.name = 'isvalid' AND f.schema_id = (SELECT s.id FROM sys.schemas s WHERE s.name = 'json') AND EXISTS (SELECT * FROM sys.args a WHERE a.func_id = f.id AND a.number = 1 AND a.type = 'json') AND f.func LIKE '%begin return true%';\n", "update", true, false, &output);
3654 96 : if (err)
3655 : return err;
3656 96 : b = BATdescriptor(output->cols[0].b);
3657 96 : if (b) {
3658 96 : if (BATcount(b) > 0) {
3659 0 : const char query[] = "drop function json.isvalid(json);\n"
3660 : "create function json.isvalid(js json)\n"
3661 : "returns bool begin return case when js is NULL then NULL else true end; end;\n"
3662 : "GRANT EXECUTE ON FUNCTION json.isvalid(json) TO PUBLIC;\n"
3663 : "update sys.functions set system = true where system <> true and name = 'isvalid' and schema_id = (select id from sys.schemas where name = 'json');\n";
3664 0 : assert(BATcount(b) == 1);
3665 0 : printf("Running database upgrade commands:\n%s\n", query);
3666 0 : fflush(stdout);
3667 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
3668 : }
3669 96 : BBPunfix(b->batCacheid);
3670 : }
3671 96 : res_table_destroy(output);
3672 96 : return err;
3673 : }
3674 :
3675 : static str
3676 96 : sql_update_dec2023_sp4(Client c, mvc *sql, sql_schema *s)
3677 : {
3678 96 : char *err;
3679 96 : res_table *output;
3680 96 : BAT *b;
3681 :
3682 96 : (void) sql;
3683 96 : (void) s;
3684 :
3685 : /* SQL optimizer fixes make that some "dependencies" are no longer
3686 : * dependencies (functions that depend on all columns of a table
3687 : * when it only actually uses a subset of the columns); while we're
3688 : * at it, also fix some ancient dependency changes where view did
3689 : * the same thing (i.e. the second delete will normally not delete
3690 : * anything) */
3691 96 : err = SQLstatementIntern(c, "select * from sys.dependencies where (id, depend_id) in (select c.id, f.id from sys.functions f, sys._tables t, sys._columns c, sys.dependencies d where c.table_id = t.id and f.id = d.depend_id and c.id = d.id and f.schema_id = 2000 and t.schema_id = 2000 and (f.name, t.name, c.name) in (values ('describe_columns', '_columns', 'storage')));\n", "update", true, false, &output);
3692 96 : if (err)
3693 : return err;
3694 96 : b = BATdescriptor(output->cols[0].b);
3695 96 : if (b) {
3696 96 : if (BATcount(b) > 0) {
3697 0 : const char query[] =
3698 : "delete from sys.dependencies where (id, depend_id) in (select c.id, f.id from sys.functions f, sys._tables t, sys._columns c, sys.dependencies d where c.table_id = t.id and f.id = d.depend_id and c.id = d.id and f.schema_id = 2000 and t.schema_id = 2000 and (f.name, t.name, c.name) in (values ('describe_columns', '_columns', 'storage'), ('describe_function', 'function_languages', 'language_name'), ('describe_function', 'function_types', 'function_type_name'), ('describe_function', 'functions', 'func'), ('describe_function', 'functions', 'mod'), ('describe_function', 'functions', 'semantics'), ('describe_function', 'functions', 'side_effect'), ('describe_function', 'functions', 'system'), ('describe_function', 'functions', 'vararg'), ('describe_function', 'functions', 'varres'), ('describe_function', 'schemas', 'authorization'), ('describe_function', 'schemas', 'owner'), ('describe_function', 'schemas', 'system'), ('describe_table', '_tables', 'access'), ('describe_table', '_tables', 'commit_action'), ('describe_table', '_tables', 'system')));\n"
3699 : "delete from sys.dependencies where (id, depend_id) in (select c.id, v.id from sys._tables v, sys._tables t, sys._columns c, sys.dependencies d where c.table_id = t.id and v.id = d.depend_id and c.id = d.id and v.schema_id = 2000 and t.schema_id = 2000 and (v.name, t.name, c.name) in (values ('dependency_columns_on_indexes', '_columns', 'name'), ('dependency_columns_on_indexes', '_columns', 'number'), ('dependency_columns_on_indexes', '_columns', 'storage'), ('dependency_columns_on_indexes', '_columns', 'table_id'), ('dependency_columns_on_indexes', '_columns', 'type_digits'), ('dependency_columns_on_indexes', 'keys', 'id'), ('dependency_columns_on_indexes', 'triggers', 'name'), ('dependency_columns_on_indexes', 'triggers', 'orientation'), ('dependency_columns_on_indexes', 'triggers', 'table_id'), ('dependency_columns_on_indexes', 'triggers', 'time'), ('dependency_columns_on_keys', '_columns', 'name'), ('dependency_columns_on_keys', '_columns', 'table_id'), ('dependency_columns_on_keys', '_columns', 'type'), ('dependency_columns_on_keys', '_columns', 'type_digits'), ('dependency_columns_on_keys', '_columns', 'type_scale'), ('dependency_columns_on_keys', 'triggers', 'name'), ('dependency_columns_on_keys', 'triggers', 'orientation'), ('dependency_columns_on_keys', 'triggers', 'table_id'), ('dependency_columns_on_keys', 'triggers', 'time'), ('dependency_columns_on_triggers', 'keys', 'name'), ('dependency_columns_on_triggers', 'keys', 'rkey'), ('dependency_columns_on_triggers', 'keys', 'type'), ('dependency_functions_on_triggers', 'keys', 'action'), ('dependency_functions_on_triggers', 'keys', 'name'), ('dependency_functions_on_triggers', 'keys', 'rkey'), ('dependency_functions_on_triggers', 'keys', 'type'), ('dependency_keys_on_foreignkeys', '_columns', 'default'), ('dependency_keys_on_foreignkeys', '_columns', 'name'), ('dependency_keys_on_foreignkeys', '_columns', 'table_id'), ('dependency_keys_on_foreignkeys', '_columns', 'type'), ('dependency_keys_on_foreignkeys', '_columns', 'type_digits'), ('dependency_keys_on_foreignkeys', '_columns', 'type_scale'), ('dependency_tables_on_foreignkeys', '_columns', 'default'), ('dependency_tables_on_foreignkeys', '_columns', 'name'), ('dependency_tables_on_foreignkeys', '_columns', 'table_id'), ('dependency_tables_on_foreignkeys', '_columns', 'type'), ('dependency_tables_on_foreignkeys', '_columns', 'type_digits'), ('dependency_tables_on_foreignkeys', '_columns', 'type_scale'), ('dependency_tables_on_indexes', '_columns', 'name'), ('dependency_tables_on_indexes', '_columns', 'number'), ('dependency_tables_on_indexes', '_columns', 'storage'), ('dependency_tables_on_indexes', '_columns', 'table_id'), ('dependency_tables_on_indexes', '_columns', 'type_digits'), ('dependency_tables_on_indexes', 'keys', 'id'), ('dependency_tables_on_triggers', 'keys', 'action'), ('dependency_tables_on_triggers', 'keys', 'name'), ('dependency_tables_on_triggers', 'keys', 'rkey'), ('dependency_tables_on_triggers', 'keys', 'type')));\n"
3700 : "delete from sys.triggers where table_id not in (select id from sys._tables);\n"
3701 : "commit;\n";
3702 0 : assert(BATcount(b) == 1);
3703 0 : printf("Running database upgrade commands:\n%s\n", query);
3704 0 : fflush(stdout);
3705 0 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
3706 0 : if (err == MAL_SUCCEED) {
3707 0 : const char query2[] =
3708 : "create temporary table d as (select distinct * from sys.dependencies);\n"
3709 : "delete from sys.dependencies;\n"
3710 : "insert into sys.dependencies (select * from d);\n";
3711 0 : printf("Running database upgrade commands:\n%s\n", query2);
3712 0 : fflush(stdout);
3713 0 : err = SQLstatementIntern(c, query2, "update", true, false, NULL);
3714 : }
3715 : }
3716 96 : BBPunfix(b->batCacheid);
3717 : }
3718 96 : res_table_destroy(output);
3719 96 : return err;
3720 : }
3721 :
3722 : static str
3723 96 : sql_update_aug2024(Client c, mvc *sql, sql_schema *s)
3724 : {
3725 96 : char *err;
3726 96 : res_table *output;
3727 96 : BAT *b;
3728 :
3729 96 : err = SQLstatementIntern(c, "SELECT id FROM sys.functions WHERE schema_id = 2000 AND name = 'describe_type' AND func LIKE '%sql_datatype%';\n", "update", true, false, &output);
3730 96 : if (err)
3731 : return err;
3732 96 : b = BATdescriptor(output->cols[0].b);
3733 96 : if (b) {
3734 96 : if (BATcount(b) == 0) {
3735 : /* do update */
3736 8 : sql_table *t;
3737 8 : const char query1[] =
3738 : "update sys._columns set type_digits = 7 where type = 'tinyint' and type_digits <> 7;\n"
3739 : "update sys._columns set type_digits = 15 where type = 'smallint' and type_digits <> 15;\n"
3740 : "update sys._columns set type_digits = 31 where type = 'int' and type_digits <> 31;\n"
3741 : "update sys._columns set type_digits = 63 where type = 'bigint' and type_digits <> 63;\n"
3742 : "update sys._columns set type_digits = 127 where type = 'hugeint' and type_digits <> 127;\n"
3743 : "update sys._columns set type = 'varchar' where type in ('clob', 'char') and table_id in (select id from sys._tables where system and name <> 'netcdf_files');\n"
3744 : "update sys.args set type_digits = 7 where type = 'tinyint' and type_digits <> 7;\n"
3745 : "update sys.args set type_digits = 15 where type = 'smallint' and type_digits <> 15;\n"
3746 : "update sys.args set type_digits = 31 where type = 'int' and type_digits <> 31;\n"
3747 : "update sys.args set type_digits = 63 where type = 'bigint' and type_digits <> 63;\n"
3748 : "update sys.args set type_digits = 127 where type = 'hugeint' and type_digits <> 127;\n"
3749 : "update sys.args set type = 'varchar' where type in ('clob', 'char');\n"
3750 : "drop aggregate median(decimal);\n"
3751 : "drop aggregate median_avg(decimal);\n"
3752 : "drop aggregate quantile(decimal, double);\n"
3753 : "drop aggregate quantile_avg(decimal, double);\n"
3754 : "create aggregate median(val DECIMAL(2)) returns DECIMAL(2)\n"
3755 : " external name \"aggr\".\"median\";\n"
3756 : "GRANT EXECUTE ON AGGREGATE median(DECIMAL(2)) TO PUBLIC;\n"
3757 : "create aggregate median(val DECIMAL(4)) returns DECIMAL(4)\n"
3758 : " external name \"aggr\".\"median\";\n"
3759 : "GRANT EXECUTE ON AGGREGATE median(DECIMAL(4)) TO PUBLIC;\n"
3760 : "create aggregate median(val DECIMAL(9)) returns DECIMAL(9)\n"
3761 : " external name \"aggr\".\"median\";\n"
3762 : "GRANT EXECUTE ON AGGREGATE median(DECIMAL(9)) TO PUBLIC;\n"
3763 : "create aggregate median(val DECIMAL(18)) returns DECIMAL(18)\n"
3764 : " external name \"aggr\".\"median\";\n"
3765 : "GRANT EXECUTE ON AGGREGATE median(DECIMAL(18)) TO PUBLIC;\n"
3766 : "create aggregate median_avg(val DECIMAL(2)) returns DOUBLE\n"
3767 : " external name \"aggr\".\"median_avg\";\n"
3768 : "GRANT EXECUTE ON AGGREGATE median_avg(DECIMAL(2)) TO PUBLIC;\n"
3769 : "create aggregate median_avg(val DECIMAL(4)) returns DOUBLE\n"
3770 : " external name \"aggr\".\"median_avg\";\n"
3771 : "GRANT EXECUTE ON AGGREGATE median_avg(DECIMAL(4)) TO PUBLIC;\n"
3772 : "create aggregate median_avg(val DECIMAL(9)) returns DOUBLE\n"
3773 : " external name \"aggr\".\"median_avg\";\n"
3774 : "GRANT EXECUTE ON AGGREGATE median_avg(DECIMAL(9)) TO PUBLIC;\n"
3775 : "create aggregate median_avg(val DECIMAL(18)) returns DOUBLE\n"
3776 : " external name \"aggr\".\"median_avg\";\n"
3777 : "GRANT EXECUTE ON AGGREGATE median_avg(DECIMAL(18)) TO PUBLIC;\n"
3778 : "create aggregate quantile(val DECIMAL(2), q DOUBLE) returns DECIMAL(2)\n"
3779 : " external name \"aggr\".\"quantile\";\n"
3780 : "GRANT EXECUTE ON AGGREGATE quantile(DECIMAL(2), DOUBLE) TO PUBLIC;\n"
3781 : "create aggregate quantile(val DECIMAL(4), q DOUBLE) returns DECIMAL(4)\n"
3782 : " external name \"aggr\".\"quantile\";\n"
3783 : "GRANT EXECUTE ON AGGREGATE quantile(DECIMAL(4), DOUBLE) TO PUBLIC;\n"
3784 : "create aggregate quantile(val DECIMAL(9), q DOUBLE) returns DECIMAL(9)\n"
3785 : " external name \"aggr\".\"quantile\";\n"
3786 : "GRANT EXECUTE ON AGGREGATE quantile(DECIMAL(9), DOUBLE) TO PUBLIC;\n"
3787 : "create aggregate quantile(val DECIMAL(18), q DOUBLE) returns DECIMAL(18)\n"
3788 : " external name \"aggr\".\"quantile\";\n"
3789 : "GRANT EXECUTE ON AGGREGATE quantile(DECIMAL(18), DOUBLE) TO PUBLIC;\n"
3790 : "create aggregate quantile_avg(val DECIMAL(2), q DOUBLE) returns DOUBLE\n"
3791 : " external name \"aggr\".\"quantile_avg\";\n"
3792 : "GRANT EXECUTE ON AGGREGATE quantile_avg(DECIMAL(2), DOUBLE) TO PUBLIC;\n"
3793 : "create aggregate quantile_avg(val DECIMAL(4), q DOUBLE) returns DOUBLE\n"
3794 : " external name \"aggr\".\"quantile_avg\";\n"
3795 : "GRANT EXECUTE ON AGGREGATE quantile_avg(DECIMAL(4), DOUBLE) TO PUBLIC;\n"
3796 : "create aggregate quantile_avg(val DECIMAL(9), q DOUBLE) returns DOUBLE\n"
3797 : " external name \"aggr\".\"quantile_avg\";\n"
3798 : "GRANT EXECUTE ON AGGREGATE quantile_avg(DECIMAL(9), DOUBLE) TO PUBLIC;\n"
3799 : "create aggregate quantile_avg(val DECIMAL(18), q DOUBLE) returns DOUBLE\n"
3800 : " external name \"aggr\".\"quantile_avg\";\n"
3801 : "GRANT EXECUTE ON AGGREGATE quantile_avg(DECIMAL(18), DOUBLE) TO PUBLIC;\n"
3802 : "drop function if exists sys.time_to_str(time with time zone, string) cascade;\n"
3803 : "drop function if exists sys.timestamp_to_str(timestamp with time zone, string) cascade;\n"
3804 : "create function time_to_str(d time, format string) returns string\n"
3805 : " external name mtime.\"time_to_str\";\n"
3806 : "create function time_to_str(d time with time zone, format string) returns string\n"
3807 : " external name mtime.\"timetz_to_str\";\n"
3808 : "create function timestamp_to_str(d timestamp with time zone, format string) returns string\n"
3809 : " external name mtime.\"timestamptz_to_str\";\n"
3810 : "grant execute on function time_to_str(time, string) to public;\n"
3811 : "grant execute on function time_to_str(time with time zone, string) to public;\n"
3812 : "grant execute on function timestamp_to_str(timestamp with time zone, string) to public;\n"
3813 : "update sys.functions set system = true where not system and schema_id = 2000 and name in ('time_to_str', 'timestamp_to_str', 'median', 'median_avg', 'quantile', 'quantile_avg');\n"
3814 : "drop function if exists sys.dump_database(boolean) cascade;\n"
3815 : "drop view sys.dump_comments;\n"
3816 : "drop view sys.dump_tables;\n"
3817 : "drop view sys.dump_functions;\n"
3818 : "drop view sys.dump_function_grants;\n"
3819 : "drop function if exists sys.describe_columns(string, string) cascade;\n"
3820 : "drop view sys.describe_functions;\n"
3821 : "drop view sys.describe_privileges;\n"
3822 : "drop view sys.describe_comments;\n"
3823 : "drop view sys.fully_qualified_functions;\n"
3824 : "drop view sys.describe_tables;\n"
3825 : "drop function if exists sys.describe_type(string, integer, integer) cascade;\n"
3826 : "CREATE FUNCTION sys.describe_type(ctype string, digits integer, tscale integer)\n"
3827 : " RETURNS string\n"
3828 : "BEGIN\n"
3829 : " RETURN sys.sql_datatype(ctype, digits, tscale, false, false);\n"
3830 : "END;\n"
3831 : "CREATE VIEW sys.describe_tables AS\n"
3832 : " SELECT\n"
3833 : " t.id o,\n"
3834 : " s.name sch,\n"
3835 : " t.name tab,\n"
3836 : " ts.table_type_name typ,\n"
3837 : " (SELECT\n"
3838 : " ' (' ||\n"
3839 : " GROUP_CONCAT(\n"
3840 : " sys.DQ(c.name) || ' ' ||\n"
3841 : " sys.describe_type(c.type, c.type_digits, c.type_scale) ||\n"
3842 : " ifthenelse(c.\"null\" = 'false', ' NOT NULL', '')\n"
3843 : " , ', ') || ')'\n"
3844 : " FROM sys._columns c\n"
3845 : " WHERE c.table_id = t.id) col,\n"
3846 : " CASE ts.table_type_name\n"
3847 : " WHEN 'REMOTE TABLE' THEN\n"
3848 : " sys.get_remote_table_expressions(s.name, t.name)\n"
3849 : " WHEN 'MERGE TABLE' THEN\n"
3850 : " sys.get_merge_table_partition_expressions(t.id)\n"
3851 : " WHEN 'VIEW' THEN\n"
3852 : " sys.schema_guard(s.name, t.name, t.query)\n"
3853 : " ELSE\n"
3854 : " ''\n"
3855 : " END opt\n"
3856 : " FROM sys.schemas s, sys.table_types ts, sys.tables t\n"
3857 : " WHERE ts.table_type_name IN ('TABLE', 'VIEW', 'MERGE TABLE', 'REMOTE TABLE', 'REPLICA TABLE', 'UNLOGGED TABLE')\n"
3858 : " AND t.system = FALSE\n"
3859 : " AND s.id = t.schema_id\n"
3860 : " AND ts.table_type_id = t.type\n"
3861 : " AND s.name <> 'tmp';\n"
3862 : "CREATE VIEW sys.fully_qualified_functions AS\n"
3863 : " WITH fqn(id, tpe, sig, num) AS\n"
3864 : " (\n"
3865 : " SELECT\n"
3866 : " f.id,\n"
3867 : " ft.function_type_keyword,\n"
3868 : " CASE WHEN a.type IS NULL THEN\n"
3869 : " sys.fqn(s.name, f.name) || '()'\n"
3870 : " ELSE\n"
3871 : " sys.fqn(s.name, f.name) || '(' || group_concat(sys.describe_type(a.type, a.type_digits, a.type_scale), ',') OVER (PARTITION BY f.id ORDER BY a.number) || ')'\n"
3872 : " END,\n"
3873 : " a.number\n"
3874 : " FROM sys.schemas s, sys.function_types ft, sys.functions f LEFT JOIN sys.args a ON f.id = a.func_id\n"
3875 : " WHERE s.id= f.schema_id AND f.type = ft.function_type_id\n"
3876 : " )\n"
3877 : " SELECT\n"
3878 : " fqn1.id id,\n"
3879 : " fqn1.tpe tpe,\n"
3880 : " fqn1.sig nme\n"
3881 : " FROM\n"
3882 : " fqn fqn1 JOIN (SELECT id, max(num) FROM fqn GROUP BY id) fqn2(id, num)\n"
3883 : " ON fqn1.id = fqn2.id AND (fqn1.num = fqn2.num OR fqn1.num IS NULL AND fqn2.num is NULL);\n"
3884 : "CREATE VIEW sys.describe_comments AS\n"
3885 : " SELECT o.id AS id, o.tpe AS tpe, o.nme AS fqn, cm.remark AS rem\n"
3886 : " FROM (\n"
3887 : " SELECT id, 'SCHEMA', sys.DQ(name) FROM sys.schemas WHERE NOT system\n"
3888 : " UNION ALL\n"
3889 : " SELECT t.id, ifthenelse(ts.table_type_name = 'VIEW', 'VIEW', 'TABLE'), sys.FQN(s.name, t.name)\n"
3890 : " FROM sys.schemas s JOIN sys._tables t ON s.id = t.schema_id JOIN sys.table_types ts ON t.type = ts.table_type_id\n"
3891 : " WHERE NOT t.system\n"
3892 : " UNION ALL\n"
3893 : " SELECT c.id, 'COLUMN', sys.FQN(s.name, t.name) || '.' || sys.DQ(c.name) FROM sys.columns c, sys._tables t, sys.schemas s WHERE NOT t.system AND c.table_id = t.id AND t.schema_id = s.id\n"
3894 : " UNION ALL\n"
3895 : " SELECT idx.id, 'INDEX', sys.FQN(s.name, idx.name) FROM sys.idxs idx, sys._tables t, sys.schemas s WHERE NOT t.system AND idx.table_id = t.id AND t.schema_id = s.id\n"
3896 : " UNION ALL\n"
3897 : " SELECT seq.id, 'SEQUENCE', sys.FQN(s.name, seq.name) FROM sys.sequences seq, sys.schemas s WHERE seq.schema_id = s.id\n"
3898 : " UNION ALL\n"
3899 : " SELECT f.id, ft.function_type_keyword, qf.nme FROM sys.functions f, sys.function_types ft, sys.schemas s, sys.fully_qualified_functions qf\n"
3900 : " WHERE NOT f.system AND f.type = ft.function_type_id AND f.schema_id = s.id AND qf.id = f.id\n"
3901 : " ) AS o(id, tpe, nme)\n"
3902 : " JOIN sys.comments cm ON cm.id = o.id;\n"
3903 : "CREATE VIEW sys.describe_privileges AS\n"
3904 : " SELECT\n"
3905 : " CASE\n"
3906 : " WHEN o.tpe IS NULL AND pc.privilege_code_name = 'SELECT' THEN --GLOBAL privileges: SELECT maps to COPY FROM\n"
3907 : " 'COPY FROM'\n"
3908 : " WHEN o.tpe IS NULL AND pc.privilege_code_name = 'UPDATE' THEN --GLOBAL privileges: UPDATE maps to COPY INTO\n"
3909 : " 'COPY INTO'\n"
3910 : " ELSE\n"
3911 : " o.nme\n"
3912 : " END o_nme,\n"
3913 : " coalesce(o.tpe, 'GLOBAL') o_tpe,\n"
3914 : " pc.privilege_code_name p_nme,\n"
3915 : " a.name a_nme,\n"
3916 : " g.name g_nme,\n"
3917 : " p.grantable grantable\n"
3918 : " FROM\n"
3919 : " sys.privileges p LEFT JOIN\n"
3920 : " (\n"
3921 : " SELECT t.id, s.name || '.' || t.name , 'TABLE'\n"
3922 : " from sys.schemas s, sys.tables t where s.id = t.schema_id\n"
3923 : " UNION ALL\n"
3924 : " SELECT c.id, s.name || '.' || t.name || '.' || c.name, 'COLUMN'\n"
3925 : " FROM sys.schemas s, sys.tables t, sys.columns c where s.id = t.schema_id AND t.id = c.table_id\n"
3926 : " UNION ALL\n"
3927 : " SELECT f.id, f.nme, f.tpe\n"
3928 : " FROM sys.fully_qualified_functions f\n"
3929 : " ) o(id, nme, tpe) ON o.id = p.obj_id,\n"
3930 : " sys.privilege_codes pc,\n"
3931 : " auths a, auths g\n"
3932 : " WHERE\n"
3933 : " p.privileges = pc.privilege_code_id AND\n"
3934 : " p.auth_id = a.id AND\n"
3935 : " p.grantor = g.id;\n"
3936 : "CREATE VIEW sys.describe_functions AS\n"
3937 : " WITH func_args_all(func_id, number, max_number, func_arg) AS\n"
3938 : " (\n"
3939 : " SELECT\n"
3940 : " func_id,\n"
3941 : " number,\n"
3942 : " max(number) OVER (PARTITION BY func_id ORDER BY number DESC),\n"
3943 : " group_concat(sys.dq(name) || ' ' || sys.describe_type(type, type_digits, type_scale),', ') OVER (PARTITION BY func_id ORDER BY number)\n"
3944 : " FROM sys.args\n"
3945 : " WHERE inout = 1\n"
3946 : " ),\n"
3947 : " func_args(func_id, func_arg) AS\n"
3948 : " (\n"
3949 : " SELECT func_id, func_arg\n"
3950 : " FROM func_args_all\n"
3951 : " WHERE number = max_number\n"
3952 : " ),\n"
3953 : " func_rets_all(func_id, number, max_number, func_ret, func_ret_type) AS\n"
3954 : " (\n"
3955 : " SELECT\n"
3956 : " func_id,\n"
3957 : " number,\n"
3958 : " max(number) OVER (PARTITION BY func_id ORDER BY number DESC),\n"
3959 : " group_concat(sys.dq(name) || ' ' || sys.describe_type(type, type_digits, type_scale),', ') OVER (PARTITION BY func_id ORDER BY number),\n"
3960 : " group_concat(sys.describe_type(type, type_digits, type_scale),', ') OVER (PARTITION BY func_id ORDER BY number)\n"
3961 : " FROM sys.args\n"
3962 : " WHERE inout = 0\n"
3963 : " ),\n"
3964 : " func_rets(func_id, func_ret, func_ret_type) AS\n"
3965 : " (\n"
3966 : " SELECT\n"
3967 : " func_id,\n"
3968 : " func_ret,\n"
3969 : " func_ret_type\n"
3970 : " FROM func_rets_all\n"
3971 : " WHERE number = max_number\n"
3972 : " )\n"
3973 : " SELECT\n"
3974 : " f.id o,\n"
3975 : " s.name sch,\n"
3976 : " f.name fun,\n"
3977 : " CASE WHEN f.language IN (1, 2) THEN f.func ELSE 'CREATE ' || ft.function_type_keyword || ' ' || sys.FQN(s.name, f.name) || '(' || coalesce(fa.func_arg, '') || ')' || CASE WHEN f.type = 5 THEN ' RETURNS TABLE (' || coalesce(fr.func_ret, '') || ')' WHEN f.type IN (1,3) THEN ' RETURNS ' || fr.func_ret_type ELSE '' END || CASE WHEN fl.language_keyword IS NULL THEN '' ELSE ' LANGUAGE ' || fl.language_keyword END || ' ' || f.func END def\n"
3978 : " FROM sys.functions f\n"
3979 : " LEFT OUTER JOIN func_args fa ON fa.func_id = f.id\n"
3980 : " LEFT OUTER JOIN func_rets fr ON fr.func_id = f.id\n"
3981 : " JOIN sys.schemas s ON f.schema_id = s.id\n"
3982 : " JOIN sys.function_types ft ON f.type = ft.function_type_id\n"
3983 : " LEFT OUTER JOIN sys.function_languages fl ON f.language = fl.language_id\n"
3984 : " WHERE s.name <> 'tmp' AND NOT f.system;\n"
3985 : "CREATE FUNCTION sys.describe_columns(schemaName string, tableName string)\n"
3986 : " RETURNS TABLE(name string, type string, digits integer, scale integer, Nulls boolean, cDefault string, number integer, sqltype string, remark string)\n"
3987 : "BEGIN\n"
3988 : " RETURN SELECT c.name, c.\"type\", c.type_digits, c.type_scale, c.\"null\", c.\"default\", c.number, sys.describe_type(c.\"type\", c.type_digits, c.type_scale), com.remark\n"
3989 : " FROM sys._tables t, sys.schemas s, sys._columns c\n"
3990 : " LEFT OUTER JOIN sys.comments com ON c.id = com.id\n"
3991 : " WHERE c.table_id = t.id\n"
3992 : " AND t.name = tableName\n"
3993 : " AND t.schema_id = s.id\n"
3994 : " AND s.name = schemaName\n"
3995 : " ORDER BY c.number;\n"
3996 : "END;\n"
3997 : "CREATE VIEW sys.dump_function_grants AS\n"
3998 : " WITH func_args_all(func_id, number, max_number, func_arg) AS\n"
3999 : " (SELECT a.func_id,\n"
4000 : " a.number,\n"
4001 : " max(a.number) OVER (PARTITION BY a.func_id ORDER BY a.number DESC),\n"
4002 : " group_concat(sys.describe_type(a.type, a.type_digits, a.type_scale), ', ') OVER (PARTITION BY a.func_id ORDER BY a.number)\n"
4003 : " FROM sys.args a\n"
4004 : " WHERE a.inout = 1),\n"
4005 : " func_args(func_id, func_arg) AS\n"
4006 : " (SELECT func_id, func_arg FROM func_args_all WHERE number = max_number)\n"
4007 : " SELECT\n"
4008 : " 'GRANT ' || pc.privilege_code_name || ' ON ' || ft.function_type_keyword || ' '\n"
4009 : " || sys.FQN(s.name, f.name) || '(' || coalesce(fa.func_arg, '') || ') TO '\n"
4010 : " || ifthenelse(a.name = 'public', 'PUBLIC', sys.dq(a.name))\n"
4011 : " || CASE WHEN p.grantable = 1 THEN ' WITH GRANT OPTION' ELSE '' END || ';' stmt,\n"
4012 : " s.name schema_name,\n"
4013 : " f.name function_name,\n"
4014 : " a.name grantee\n"
4015 : " FROM sys.schemas s,\n"
4016 : " sys.functions f LEFT OUTER JOIN func_args fa ON f.id = fa.func_id,\n"
4017 : " sys.auths a,\n"
4018 : " sys.privileges p,\n"
4019 : " sys.auths g,\n"
4020 : " sys.function_types ft,\n"
4021 : " sys.privilege_codes pc\n"
4022 : " WHERE s.id = f.schema_id\n"
4023 : " AND f.id = p.obj_id\n"
4024 : " AND p.auth_id = a.id\n"
4025 : " AND p.grantor = g.id\n"
4026 : " AND p.privileges = pc.privilege_code_id\n"
4027 : " AND f.type = ft.function_type_id\n"
4028 : " AND NOT f.system\n"
4029 : " ORDER BY s.name, f.name, a.name, g.name, p.grantable;\n"
4030 : "CREATE VIEW sys.dump_functions AS\n"
4031 : " SELECT f.o o, sys.schema_guard(f.sch, f.fun, f.def) stmt,\n"
4032 : " f.sch schema_name,\n"
4033 : " f.fun function_name\n"
4034 : " FROM sys.describe_functions f;\n"
4035 : "CREATE VIEW sys.dump_tables AS\n"
4036 : " SELECT\n"
4037 : " t.o o,\n"
4038 : " CASE\n"
4039 : " WHEN t.typ <> 'VIEW' THEN\n"
4040 : " 'CREATE ' || t.typ || ' ' || sys.FQN(t.sch, t.tab) || t.col || t.opt || ';'\n"
4041 : " ELSE\n"
4042 : " t.opt\n"
4043 : " END stmt,\n"
4044 : " t.sch schema_name,\n"
4045 : " t.tab table_name\n"
4046 : " FROM sys.describe_tables t;\n"
4047 : "CREATE VIEW sys.dump_comments AS\n"
4048 : " SELECT 'COMMENT ON ' || c.tpe || ' ' || c.fqn || ' IS ' || sys.SQ(c.rem) || ';' stmt FROM sys.describe_comments c;\n"
4049 : "CREATE FUNCTION sys.dump_database(describe BOOLEAN) RETURNS TABLE(o int, stmt STRING)\n"
4050 : "BEGIN\n"
4051 : " SET SCHEMA sys;\n"
4052 : " TRUNCATE sys.dump_statements;\n"
4053 : " INSERT INTO sys.dump_statements VALUES (1, 'START TRANSACTION;');\n"
4054 : " INSERT INTO sys.dump_statements VALUES (2, 'SET SCHEMA \"sys\";');\n"
4055 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_roles;\n"
4056 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_users;\n"
4057 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_create_schemas;\n"
4058 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_user_defined_types;\n"
4059 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_add_schemas_to_users;\n"
4060 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_grant_user_privileges;\n"
4061 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_sequences;\n"
4062 : " --functions and table-likes can be interdependent. They should be inserted in the order of their catalogue id.\n"
4063 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(ORDER BY stmts.o), stmts.s\n"
4064 : " FROM (\n"
4065 : " SELECT f.o, f.stmt FROM sys.dump_functions f\n"
4066 : " UNION ALL\n"
4067 : " SELECT t.o, t.stmt FROM sys.dump_tables t\n"
4068 : " ) AS stmts(o, s);\n"
4069 : " -- dump table data before adding constraints and fixing sequences\n"
4070 : " IF NOT DESCRIBE THEN\n"
4071 : " CALL sys.dump_table_data();\n"
4072 : " END IF;\n"
4073 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_start_sequences;\n"
4074 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_defaults;\n"
4075 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_constraint_type;\n"
4076 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_indices;\n"
4077 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_foreign_keys;\n"
4078 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_partition_tables;\n"
4079 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_triggers;\n"
4080 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_comments;\n"
4081 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_table_grants;\n"
4082 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_column_grants;\n"
4083 : " INSERT INTO sys.dump_statements SELECT (SELECT COUNT(*) FROM sys.dump_statements) + RANK() OVER(), stmt FROM sys.dump_function_grants;\n"
4084 : " --TODO Improve performance of dump_table_data.\n"
4085 : " --TODO loaders, procedures, window and filter sys.functions.\n"
4086 : " --TODO look into order dependent group_concat\n"
4087 : " INSERT INTO sys.dump_statements VALUES ((SELECT COUNT(*) FROM sys.dump_statements) + 1, 'COMMIT;');\n"
4088 : " RETURN sys.dump_statements;\n"
4089 : "END;\n"
4090 : "GRANT SELECT ON sys.describe_tables TO PUBLIC;\n"
4091 : "GRANT SELECT ON sys.describe_comments TO PUBLIC;\n"
4092 : "GRANT SELECT ON sys.fully_qualified_functions TO PUBLIC;\n"
4093 : "GRANT SELECT ON sys.describe_privileges TO PUBLIC;\n"
4094 : "GRANT SELECT ON sys.describe_functions TO PUBLIC;\n"
4095 : "CREATE FUNCTION sys.check_constraint(sname STRING, cname STRING) RETURNS STRING EXTERNAL NAME sql.\"check\";\n"
4096 : "grant execute on function sys.check_constraint to public;\n"
4097 : "update sys.functions set system = true where not system and schema_id = 2000 and name in ('dump_database', 'describe_columns', 'describe_type', 'check_constraint');\n"
4098 : "update sys._tables set system = true where not system and schema_id = 2000 and name in ('dump_comments', 'dump_tables', 'dump_functions', 'dump_function_grants', 'describe_functions', 'describe_privileges', 'describe_comments', 'fully_qualified_functions', 'describe_tables');\n";
4099 8 : if ((t = mvc_bind_table(sql, s, "dump_comments")) != NULL)
4100 8 : t->system = 0;
4101 8 : if ((t = mvc_bind_table(sql, s, "dump_tables")) != NULL)
4102 8 : t->system = 0;
4103 8 : if ((t = mvc_bind_table(sql, s, "dump_functions")) != NULL)
4104 8 : t->system = 0;
4105 8 : if ((t = mvc_bind_table(sql, s, "dump_function_grants")) != NULL)
4106 8 : t->system = 0;
4107 8 : if ((t = mvc_bind_table(sql, s, "describe_functions")) != NULL)
4108 8 : t->system = 0;
4109 8 : if ((t = mvc_bind_table(sql, s, "describe_privileges")) != NULL)
4110 8 : t->system = 0;
4111 8 : if ((t = mvc_bind_table(sql, s, "describe_comments")) != NULL)
4112 8 : t->system = 0;
4113 8 : if ((t = mvc_bind_table(sql, s, "fully_qualified_functions")) != NULL)
4114 8 : t->system = 0;
4115 8 : if ((t = mvc_bind_table(sql, s, "describe_tables")) != NULL)
4116 8 : t->system = 0;
4117 8 : printf("Running database upgrade commands:\n%s\n", query1);
4118 8 : fflush(stdout);
4119 8 : err = SQLstatementIntern(c, query1, "update", true, false, NULL);
4120 : #ifdef HAVE_HGE
4121 8 : if (err == MAL_SUCCEED) {
4122 8 : sql_subtype tp;
4123 8 : sql_find_subtype(&tp, "decimal", 38, 0);
4124 8 : if (!sql_bind_func(sql, s->base.name, "median", &tp, NULL, F_AGGR, true, true)) {
4125 4 : sql->session->status = 0;
4126 4 : sql->errstr[0] = '\0';
4127 4 : const char query0[] =
4128 : "create aggregate median(val DECIMAL(38)) returns DECIMAL(38)\n"
4129 : " external name \"aggr\".\"median\";\n"
4130 : "GRANT EXECUTE ON AGGREGATE median(DECIMAL(38)) TO PUBLIC;\n"
4131 : "create aggregate median_avg(val DECIMAL(38)) returns DOUBLE\n"
4132 : " external name \"aggr\".\"median_avg\";\n"
4133 : "GRANT EXECUTE ON AGGREGATE median_avg(DECIMAL(38)) TO PUBLIC;\n"
4134 : "create aggregate quantile(val DECIMAL(38), q DOUBLE) returns DECIMAL(38)\n"
4135 : " external name \"aggr\".\"quantile\";\n"
4136 : "GRANT EXECUTE ON AGGREGATE quantile(DECIMAL(38), DOUBLE) TO PUBLIC;\n"
4137 : "create aggregate quantile_avg(val DECIMAL(38), q DOUBLE) returns DOUBLE\n"
4138 : " external name \"aggr\".\"quantile_avg\";\n"
4139 : "GRANT EXECUTE ON AGGREGATE quantile_avg(DECIMAL(38), DOUBLE) TO PUBLIC;\n"
4140 : "grant execute on function sys.generate_series(hugeint, hugeint) to public;\n"
4141 : "grant execute on function sys.generate_series(hugeint, hugeint, hugeint) to public;\n"
4142 : "update sys.functions set system = true where system <> true and schema_id = 2000 and name in ('median', 'median_avg', 'quantile', 'quantile_avg');\n";
4143 4 : printf("Running database upgrade commands:\n%s\n", query0);
4144 4 : fflush(stdout);
4145 4 : err = SQLstatementIntern(c, query0, "update", true, false, NULL);
4146 : }
4147 : }
4148 : #endif
4149 8 : if (err == MAL_SUCCEED) {
4150 8 : sql_subtype tp;
4151 8 : sql_find_subtype(&tp, "smallint", 0, 0);
4152 8 : if (!sql_bind_func(sql, s->base.name, "generate_series", &tp, &tp, F_UNION, true, true)) {
4153 2 : sql->session->status = 0;
4154 2 : sql->errstr[0] = '\0';
4155 2 : const char query[] =
4156 : "create function sys.generate_series(first smallint, \"limit\" smallint)\n"
4157 : "returns table (value smallint)\n"
4158 : "external name generator.series;\n"
4159 : "create function sys.generate_series(first smallint, \"limit\" smallint, stepsize smallint)\n"
4160 : "returns table (value smallint)\n"
4161 : "external name generator.series;\n"
4162 : "update sys.functions set system = true where system <> true and name in ('generate_series') and schema_id = 2000;\n";
4163 2 : printf("Running database upgrade commands:\n%s\n", query);
4164 2 : fflush(stdout);
4165 2 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
4166 : }
4167 : }
4168 8 : if (err == MAL_SUCCEED) {
4169 8 : const char query[] =
4170 : "create function sys.generate_series(first date, \"limit\" date, stepsize interval month)\n"
4171 : "returns table (value date)\n"
4172 : "external name generator.series;\n"
4173 : "create function sys.generate_series(first date, \"limit\" date, stepsize interval day)\n"
4174 : "returns table (value date)\n"
4175 : "external name generator.series;\n"
4176 : "grant execute on function sys.generate_series(tinyint, tinyint) to public;\n"
4177 : "grant execute on function sys.generate_series(tinyint, tinyint, tinyint) to public;\n"
4178 : "grant execute on function sys.generate_series(smallint, smallint) to public;\n"
4179 : "grant execute on function sys.generate_series(smallint, smallint, smallint) to public;\n"
4180 : "grant execute on function sys.generate_series(int, int) to public;\n"
4181 : "grant execute on function sys.generate_series(int, int, int) to public;\n"
4182 : "grant execute on function sys.generate_series(bigint, bigint) to public;\n"
4183 : "grant execute on function sys.generate_series(bigint, bigint, bigint) to public;\n"
4184 : "grant execute on function sys.generate_series(real, real, real) to public;\n"
4185 : "grant execute on function sys.generate_series(double, double, double) to public;\n"
4186 : "grant execute on function sys.generate_series(decimal(10,2), decimal(10,2), decimal(10,2)) to public;\n"
4187 : "grant execute on function sys.generate_series(date, date, interval month) to public;\n"
4188 : "grant execute on function sys.generate_series(date, date, interval day) to public;\n"
4189 : "grant execute on function sys.generate_series(timestamp, timestamp, interval second) to public;\n"
4190 : "grant execute on function sys.generate_series(timestamp, timestamp, interval day) to public;\n"
4191 : "update sys.functions set system = true where system <> true and name = 'generate_series' and schema_id = 2000;\n";
4192 8 : sql->session->status = 0;
4193 8 : sql->errstr[0] = '\0';
4194 8 : printf("Running database upgrade commands:\n%s\n", query);
4195 8 : fflush(stdout);
4196 8 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
4197 : }
4198 8 : if (err == MAL_SUCCEED) {
4199 8 : const char query[] =
4200 : "drop view sys.sessions;\n"
4201 : "drop function sys.sessions();\n"
4202 : "create function sys.sessions()\n"
4203 : " returns table(\n"
4204 : " \"sessionid\" int,\n"
4205 : " \"username\" string,\n"
4206 : " \"login\" timestamp,\n"
4207 : " \"idle\" timestamp,\n"
4208 : " \"optimizer\" string,\n"
4209 : " \"sessiontimeout\" int,\n"
4210 : " \"querytimeout\" int,\n"
4211 : " \"workerlimit\" int,\n"
4212 : " \"memorylimit\" int,\n"
4213 : " \"language\" string,\n"
4214 : " \"peer\" string,\n"
4215 : " \"hostname\" string,\n"
4216 : " \"application\" string,\n"
4217 : " \"client\" string,\n"
4218 : " \"clientpid\" bigint,\n"
4219 : " \"remark\" string\n"
4220 : " )\n"
4221 : " external name sql.sessions;\n"
4222 : "create view sys.sessions as select * from sys.sessions();\n"
4223 : "grant select on sys.sessions to public;\n"
4224 : "create procedure sys.setclientinfo(property string, value string)\n"
4225 : " external name clients.setinfo;\n"
4226 : "grant execute on procedure sys.setclientinfo(string, string) to public;\n"
4227 : "create table sys.clientinfo_properties(prop varchar(40) NOT NULL, session_attr varchar(40) NOT NULL);\n"
4228 : "insert into sys.clientinfo_properties values\n"
4229 : " ('ClientHostname', 'hostname'),\n"
4230 : " ('ApplicationName', 'application'),\n"
4231 : " ('ClientLibrary', 'client'),\n"
4232 : " ('ClientPid', 'clientpid'),\n"
4233 : " ('ClientRemark', 'remark');\n"
4234 : "grant select on sys.clientinfo_properties to public;\n"
4235 : "update sys.functions set system = true where schema_id = 2000 and name in ('setclientinfo', 'sessions');\n"
4236 : "update sys._tables set system = true where schema_id = 2000 and name in ('clientinfo_properties', 'sessions');\n";
4237 :
4238 8 : t = mvc_bind_table(sql, s, "sessions");
4239 8 : t->system = 0; /* make it non-system else the drop view will fail */
4240 8 : printf("Running database upgrade commands:\n%s\n", query);
4241 8 : fflush(stdout);
4242 8 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
4243 : }
4244 8 : if (err == MAL_SUCCEED) {
4245 8 : const char query[] = "alter table sys.clientinfo_properties SET READ ONLY;\n";
4246 8 : printf("Running database upgrade commands:\n%s\n", query);
4247 8 : fflush(stdout);
4248 8 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
4249 : }
4250 8 : if (err == MAL_SUCCEED) {
4251 8 : const char query[] =
4252 : "DROP TABLE sys.key_types;\n"
4253 : "CREATE TABLE sys.key_types (\n"
4254 : " key_type_id SMALLINT NOT NULL PRIMARY KEY,\n"
4255 : " key_type_name VARCHAR(35) NOT NULL UNIQUE);\n"
4256 : "INSERT INTO sys.key_types VALUES\n"
4257 : "(0, 'Primary Key'),\n"
4258 : "(1, 'Unique Key'),\n"
4259 : "(2, 'Foreign Key'),\n"
4260 : "(3, 'Unique Key With Nulls Not Distinct'),\n"
4261 : "(4, 'Check Constraint');\n"
4262 : "GRANT SELECT ON sys.key_types TO PUBLIC;\n"
4263 : "UPDATE sys._tables SET system = true WHERE schema_id = 2000 AND name = 'key_types';\n";
4264 8 : if ((t = mvc_bind_table(sql, s, "key_types")) != NULL)
4265 8 : t->system = 0;
4266 8 : printf("Running database upgrade commands:\n%s\n", query);
4267 8 : fflush(stdout);
4268 8 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
4269 : }
4270 8 : if (err == MAL_SUCCEED) {
4271 8 : const char query[] = "ALTER TABLE sys.key_types SET READ ONLY;\n";
4272 8 : printf("Running database upgrade commands:\n%s\n", query);
4273 8 : fflush(stdout);
4274 8 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
4275 : }
4276 8 : if (err == MAL_SUCCEED) {
4277 8 : const char query[] =
4278 : "DROP VIEW information_schema.check_constraints CASCADE;\n"
4279 : "DROP VIEW information_schema.table_constraints CASCADE;\n"
4280 : "CREATE VIEW INFORMATION_SCHEMA.CHECK_CONSTRAINTS AS SELECT\n"
4281 : " cast(NULL AS varchar(1)) AS CONSTRAINT_CATALOG,\n"
4282 : " s.\"name\" AS CONSTRAINT_SCHEMA,\n"
4283 : " k.\"name\" AS CONSTRAINT_NAME,\n"
4284 : " cast(sys.check_constraint(s.\"name\", k.\"name\") AS varchar(2048)) AS CHECK_CLAUSE,\n"
4285 : " t.\"schema_id\" AS schema_id,\n"
4286 : " t.\"id\" AS table_id,\n"
4287 : " t.\"name\" AS table_name,\n"
4288 : " k.\"id\" AS key_id\n"
4289 : " FROM (SELECT sk.\"id\", sk.\"table_id\", sk.\"name\" FROM sys.\"keys\" sk WHERE sk.\"type\" = 4 UNION ALL SELECT tk.\"id\", tk.\"table_id\", tk.\"name\" FROM tmp.\"keys\" tk WHERE tk.\"type\" = 4) k\n"
4290 : " INNER JOIN (SELECT st.\"id\", st.\"schema_id\", st.\"name\" FROM sys.\"_tables\" st UNION ALL SELECT tt.\"id\", tt.\"schema_id\", tt.\"name\" FROM tmp.\"_tables\" tt) t ON k.\"table_id\" = t.\"id\"\n"
4291 : " INNER JOIN sys.\"schemas\" s ON t.\"schema_id\" = s.\"id\"\n"
4292 : " ORDER BY s.\"name\", t.\"name\", k.\"name\";\n"
4293 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.CHECK_CONSTRAINTS TO PUBLIC WITH GRANT OPTION;\n"
4294 :
4295 : "CREATE VIEW INFORMATION_SCHEMA.TABLE_CONSTRAINTS AS SELECT\n"
4296 : " cast(NULL AS varchar(1)) AS CONSTRAINT_CATALOG,\n"
4297 : " s.\"name\" AS CONSTRAINT_SCHEMA,\n"
4298 : " k.\"name\" AS CONSTRAINT_NAME,\n"
4299 : " cast(NULL AS varchar(1)) AS TABLE_CATALOG,\n"
4300 : " s.\"name\" AS TABLE_SCHEMA,\n"
4301 : " t.\"name\" AS TABLE_NAME,\n"
4302 : " cast(CASE k.\"type\" WHEN 0 THEN 'PRIMARY KEY' WHEN 1 THEN 'UNIQUE' WHEN 2 THEN 'FOREIGN KEY' WHEN 3 THEN 'UNIQUE NULLS NOT DISTINCT' WHEN 4 THEN 'CHECK' ELSE NULL END AS varchar(26)) AS CONSTRAINT_TYPE,\n"
4303 : " cast('NO' AS varchar(3)) AS IS_DEFERRABLE,\n"
4304 : " cast('NO' AS varchar(3)) AS INITIALLY_DEFERRED,\n"
4305 : " cast('YES' AS varchar(3)) AS ENFORCED,\n"
4306 : " t.\"schema_id\" AS schema_id,\n"
4307 : " t.\"id\" AS table_id,\n"
4308 : " k.\"id\" AS key_id,\n"
4309 : " k.\"type\" AS key_type,\n"
4310 : " t.\"system\" AS is_system\n"
4311 : " FROM (SELECT sk.\"id\", sk.\"table_id\", sk.\"name\", sk.\"type\" FROM sys.\"keys\" sk UNION ALL SELECT tk.\"id\", tk.\"table_id\", tk.\"name\", tk.\"type\" FROM tmp.\"keys\" tk) k\n"
4312 : " INNER JOIN (SELECT st.\"id\", st.\"schema_id\", st.\"name\", st.\"system\" FROM sys.\"_tables\" st UNION ALL SELECT tt.\"id\", tt.\"schema_id\", tt.\"name\", tt.\"system\" FROM tmp.\"_tables\" tt) t ON k.\"table_id\" = t.\"id\"\n"
4313 : " INNER JOIN sys.\"schemas\" s ON t.\"schema_id\" = s.\"id\"\n"
4314 : " ORDER BY s.\"name\", t.\"name\", k.\"name\";\n"
4315 : "GRANT SELECT ON TABLE INFORMATION_SCHEMA.TABLE_CONSTRAINTS TO PUBLIC WITH GRANT OPTION;\n"
4316 : "\n"
4317 : "UPDATE sys._tables SET system = true where system <> true\n"
4318 : " and schema_id = (select s.id from sys.schemas s where s.name = 'information_schema')\n"
4319 : " and name in ('check_constraints','table_constraints');\n";
4320 8 : sql_schema *infoschema = mvc_bind_schema(sql, "information_schema");
4321 8 : if ((t = mvc_bind_table(sql, infoschema, "check_constraints")) != NULL)
4322 8 : t->system = 0; /* make it non-system else the drop view will fail */
4323 8 : if ((t = mvc_bind_table(sql, infoschema, "table_constraints")) != NULL)
4324 8 : t->system = 0;
4325 8 : printf("Running database upgrade commands:\n%s\n", query);
4326 8 : fflush(stdout);
4327 8 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
4328 : }
4329 8 : if (err == MAL_SUCCEED) {
4330 8 : sql_subtype tp;
4331 8 : sql_find_subtype(&tp, "varchar", 0, 0);
4332 8 : if (sql_bind_func(sql, s->base.name, "gzcompress", &tp, &tp, F_PROC, true, true)) {
4333 2 : const char query[] =
4334 : "drop procedure if exists sys.gzcompress(string, string);\n"
4335 : "drop procedure if exists sys.gzdecompress(string, string);\n"
4336 : "drop procedure if exists sys.gztruncate(string, string);\n"
4337 : "drop procedure if exists sys.gzexpand(string, string);\n";
4338 2 : printf("Running database upgrade commands:\n%s\n", query);
4339 2 : fflush(stdout);
4340 2 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
4341 : } else {
4342 6 : sql->session->status = 0;
4343 6 : sql->errstr[0] = '\0';
4344 : }
4345 : }
4346 8 : if (err == MAL_SUCCEED) {
4347 8 : sql_subtype tp;
4348 8 : sql_find_subtype(&tp, "varchar", 0, 0);
4349 8 : if (sql_bind_func(sql, s->base.name, "newdictionary", &tp, &tp, F_PROC, true, true)) {
4350 2 : const char query[] =
4351 : "drop procedure if exists sys.newdictionary(string, string);\n"
4352 : "drop procedure if exists sys.dropdictionary(string, string);\n"
4353 : "drop procedure if exists sys.initializedictionary();\n";
4354 2 : printf("Running database upgrade commands:\n%s\n", query);
4355 2 : fflush(stdout);
4356 2 : err = SQLstatementIntern(c, query, "update", true, false, NULL);
4357 : } else {
4358 6 : sql->session->status = 0;
4359 6 : sql->errstr[0] = '\0';
4360 : }
4361 : }
4362 : }
4363 96 : BBPunfix(b->batCacheid);
4364 : }
4365 96 : res_table_destroy(output);
4366 :
4367 96 : return err;
4368 : }
4369 :
4370 : int
4371 96 : SQLupgrades(Client c, mvc *m)
4372 : {
4373 96 : char *err;
4374 96 : sql_schema *s = mvc_bind_schema(m, "sys");
4375 :
4376 96 : if ((err = check_sys_tables(c, m, s)) != NULL) {
4377 0 : goto handle_error;
4378 : }
4379 :
4380 : #ifdef HAVE_HGE
4381 96 : sql_subtype tp;
4382 96 : sql_find_subtype(&tp, "hugeint", 0, 0);
4383 96 : if (!sql_bind_func(m, s->base.name, "var_pop", &tp, NULL, F_AGGR, true, true)) {
4384 8 : m->session->status = 0; /* if the function was not found clean the error */
4385 8 : m->errstr[0] = '\0';
4386 8 : if ((err = sql_update_hugeint(c, m)) != NULL) {
4387 0 : goto handle_error;
4388 : }
4389 : }
4390 : #endif
4391 :
4392 96 : if ((err = sql_update_jan2022(c, m)) != NULL) {
4393 0 : goto handle_error;
4394 : }
4395 :
4396 96 : if ((err = sql_update_sep2022(c, m, s)) != NULL) {
4397 0 : goto handle_error;
4398 : }
4399 :
4400 96 : if ((err = sql_update_jun2023(c, m, s)) != NULL) {
4401 0 : goto handle_error;
4402 : }
4403 :
4404 96 : if ((err = sql_update_dec2023_geom(c, m, s)) != NULL) {
4405 0 : goto handle_error;
4406 : }
4407 :
4408 96 : if ((err = sql_update_jun2023_sp3(c, m, s)) != NULL) {
4409 0 : goto handle_error;
4410 : }
4411 :
4412 96 : if ((err = sql_update_dec2023(c, m, s)) != NULL) {
4413 0 : goto handle_error;
4414 : }
4415 :
4416 96 : if ((err = sql_update_dec2023_sp1(c, m, s)) != NULL) {
4417 0 : goto handle_error;
4418 : }
4419 :
4420 96 : if ((err = sql_update_dec2023_sp4(c, m, s)) != NULL) {
4421 0 : goto handle_error;
4422 : }
4423 :
4424 96 : if ((err = sql_update_aug2024(c, m, s)) != NULL) {
4425 0 : goto handle_error;
4426 : }
4427 :
4428 96 : return 0;
4429 :
4430 0 : handle_error:
4431 0 : GDKfatal("%s\n", err);
4432 : freeException(err);
4433 : return -1;
4434 : }
|