Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Automatically run ANALYZE after babelfish extension create/upgrade #1922

Merged
26 changes: 26 additions & 0 deletions contrib/babelfishpg_tsql/sql/ownership.sql
Original file line number Diff line number Diff line change
Expand Up @@ -227,6 +227,30 @@ BEGIN
END
$$;

CREATE OR REPLACE PROCEDURE sys.analyze_babelfish_catalogs()
sumitj824 marked this conversation as resolved.
Show resolved Hide resolved
LANGUAGE plpgsql
AS $$
DECLARE
babelfish_catalog RECORD;
schema_name varchar = 'sys';
error_msg text;
BEGIN
FOR babelfish_catalog IN (
SELECT relname as name from pg_class t
INNER JOIN pg_namespace n on n.oid = t.relnamespace
WHERE t.relkind = 'r' and n.nspname = schema_name
)
LOOP
BEGIN
EXECUTE format('ANALYZE %I.%I', schema_name, babelfish_catalog.name);
EXCEPTION WHEN OTHERS THEN
GET STACKED DIAGNOSTICS error_msg = MESSAGE_TEXT;
RAISE WARNING 'ANALYZE for babelfish catalog %.% failed with error: %s', schema_name, babelfish_catalog.name, error_msg;
END;
END LOOP;
END;
$$;

CREATE OR REPLACE PROCEDURE initialize_babelfish ( sa_name VARCHAR(128) )
LANGUAGE plpgsql
AS $$
Expand Down Expand Up @@ -266,6 +290,8 @@ BEGIN
CALL sys.babel_initialize_logins('sysadmin');
CALL sys.babel_create_builtin_dbs(sa_name);
CALL sys.initialize_babel_extras();
-- run analyze for all babelfish catalog
CALL sys.analyze_babelfish_catalogs();
END
$$;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2543,6 +2543,30 @@ GRANT EXECUTE ON FUNCTION sys.has_perms_by_name(
permission sys.SYSNAME,
sub_securable sys.SYSNAME,
sub_securable_class sys.nvarchar(60)) TO PUBLIC;

CREATE OR REPLACE PROCEDURE sys.analyze_babelfish_catalogs()
LANGUAGE plpgsql
AS $$
DECLARE
babelfish_catalog RECORD;
schema_name varchar = 'sys';
error_msg text;
BEGIN
FOR babelfish_catalog IN (
SELECT relname as name from pg_class t
INNER JOIN pg_namespace n on n.oid = t.relnamespace
WHERE t.relkind = 'r' and n.nspname = schema_name
)
LOOP
BEGIN
EXECUTE format('ANALYZE %I.%I', schema_name, babelfish_catalog.name);
EXCEPTION WHEN OTHERS THEN
GET STACKED DIAGNOSTICS error_msg = MESSAGE_TEXT;
RAISE WARNING 'ANALYZE for babelfish catalog %.% failed with error: %s', schema_name, babelfish_catalog.name, error_msg;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When we have this warning in the upgrade, what's our action item ?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Warning will help us to debug any performance issue after upgrade due the failure. I will add the same in Jira also.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

how will it lead to action on customer or our side? A warning will go to upgrade scripts and might be lost if no one takes a look.

Copy link
Contributor Author

@sumitj824 sumitj824 Oct 24, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes, warning will not lead to any action but it will be helpful for any performance issue observed just after the upgrade and logs are present.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let us track this item via a Jira. Talk to Sharu about this. We should consider how we track successful MVUs and corresponding logs in long term to resolve issues down the line.

END;
END LOOP;
END;
$$;

-- This is a temporary procedure which is called during upgrade to update guest schema
-- for the guest users in the already existing databases
Expand All @@ -2560,6 +2584,10 @@ DROP PROCEDURE sys.babelfish_update_user_catalog_for_guest_schema();
-- Please have this be one of the last statements executed in this upgrade script.
DROP PROCEDURE sys.babelfish_drop_deprecated_object(varchar, varchar, varchar);

-- After upgrade, always run analyze for all babelfish catalogs.
CALL sys.analyze_babelfish_catalogs();
sumitj824 marked this conversation as resolved.
Show resolved Hide resolved

-- Reset search_path to not affect any subsequent scripts
SELECT set_config('search_path', trim(leading 'sys, ' from current_setting('search_path')), false);


Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
-- function to list all the babelfish catalogs that has not been analyzed manually
CREATE FUNCTION auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
RETURNS TABLE
AS RETURN
(SELECT relname FROM pg_stat_all_tables WHERE schemaname = 'sys' and last_analyze IS NULL)
GO

-- function to list all the babelfish catalogs that has been analyzed manually
CREATE FUNCTION auto_analyze_vu_prepare_catalogs_have_been_analyzed()
RETURNS TABLE
AS RETURN
(SELECT relname FROM pg_stat_all_tables WHERE schemaname = 'sys' and last_analyze IS NOT NULL)
GO


-- will return null as none of the catalog has been analyzed
SELECT * FROM auto_analyze_vu_prepare_catalogs_have_been_analyzed()
GO
~~START~~
varchar
~~END~~

15 changes: 15 additions & 0 deletions test/JDBC/expected/AUTO_ANALYZE-before-15-5-or-14-10-vu-verify.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@

-- list all the babelfish catalogs that has not been analyzed manually after upgrade
-- will return null
SELECT * FROM auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
GO
~~START~~
varchar
~~END~~


DROP FUNCTION auto_analyze_vu_prepare_catalogs_have_not_been_analyzed
GO

DROP FUNCTION auto_analyze_vu_prepare_catalogs_have_been_analyzed
GO
22 changes: 22 additions & 0 deletions test/JDBC/expected/AUTO_ANALYZE-vu-prepare.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
-- function to list all the babelfish catalogs that has not been analyzed manually
CREATE FUNCTION auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
RETURNS TABLE
AS RETURN
(SELECT relname FROM pg_stat_all_tables WHERE schemaname = 'sys' and last_analyze IS NULL)
GO

-- function to list all the babelfish catalogs that has been analyzed manually
CREATE FUNCTION auto_analyze_vu_prepare_catalogs_have_been_analyzed()
RETURNS TABLE
AS RETURN
(SELECT relname FROM pg_stat_all_tables WHERE schemaname = 'sys' and last_analyze IS NOT NULL)
GO
sumitj824 marked this conversation as resolved.
Show resolved Hide resolved


-- will return null as all of the catalog has been analyzed during extension create
SELECT * FROM auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
GO
~~START~~
varchar
~~END~~

15 changes: 15 additions & 0 deletions test/JDBC/expected/AUTO_ANALYZE-vu-verify.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@

-- list all the babelfish catalogs that has not been analyzed manually after upgrade
-- will return null
SELECT * FROM auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
GO
~~START~~
varchar
~~END~~


DROP FUNCTION auto_analyze_vu_prepare_catalogs_have_not_been_analyzed
GO

DROP FUNCTION auto_analyze_vu_prepare_catalogs_have_been_analyzed
GO
4 changes: 2 additions & 2 deletions test/JDBC/expected/openquery_upgrd_before_15_4-vu-prepare.out
Original file line number Diff line number Diff line change
Expand Up @@ -177,13 +177,13 @@ EXEC sp_serveroption @server='bbf_server_2', @optname='connect timeout', @optval
GO

-- check if the linked servers added above are reflected in babelfish_server_options catalog
SELECT servername, query_timeout, connect_timeout FROM babelfish_server_options WHERE servername = 'bbf_server' OR servername = 'bbf_server_1' OR servername = 'bbf_server_2'
SELECT servername, query_timeout, connect_timeout FROM babelfish_server_options WHERE servername = 'bbf_server' OR servername = 'bbf_server_1' OR servername = 'bbf_server_2' order by servername
GO
~~START~~
varchar#!#int#!#int
bbf_server#!#0#!#0
bbf_server_2#!#0#!#1
bbf_server_1#!#1#!#5
bbf_server_2#!#0#!#1
~~END~~


Expand Down
18 changes: 18 additions & 0 deletions test/JDBC/input/AUTO_ANALYZE-before-15-5-or-14-10-vu-prepare.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
-- function to list all the babelfish catalogs that has not been analyzed manually
CREATE FUNCTION auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
RETURNS TABLE
AS RETURN
(SELECT relname FROM pg_stat_all_tables WHERE schemaname = 'sys' and last_analyze IS NULL)
GO

-- function to list all the babelfish catalogs that has been analyzed manually
CREATE FUNCTION auto_analyze_vu_prepare_catalogs_have_been_analyzed()
RETURNS TABLE
AS RETURN
(SELECT relname FROM pg_stat_all_tables WHERE schemaname = 'sys' and last_analyze IS NOT NULL)
GO


-- will return null as none of the catalog has been analyzed
sumitj824 marked this conversation as resolved.
Show resolved Hide resolved
SELECT * FROM auto_analyze_vu_prepare_catalogs_have_been_analyzed()
GO
11 changes: 11 additions & 0 deletions test/JDBC/input/AUTO_ANALYZE-before-15-5-or-14-10-vu-verify.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@

-- list all the babelfish catalogs that has not been analyzed manually after upgrade
-- will return null
SELECT * FROM auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
GO

DROP FUNCTION auto_analyze_vu_prepare_catalogs_have_not_been_analyzed
GO

DROP FUNCTION auto_analyze_vu_prepare_catalogs_have_been_analyzed
GO
18 changes: 18 additions & 0 deletions test/JDBC/input/AUTO_ANALYZE-vu-prepare.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
-- function to list all the babelfish catalogs that has not been analyzed manually
CREATE FUNCTION auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
RETURNS TABLE
AS RETURN
(SELECT relname FROM pg_stat_all_tables WHERE schemaname = 'sys' and last_analyze IS NULL)
GO

-- function to list all the babelfish catalogs that has been analyzed manually
CREATE FUNCTION auto_analyze_vu_prepare_catalogs_have_been_analyzed()
RETURNS TABLE
AS RETURN
(SELECT relname FROM pg_stat_all_tables WHERE schemaname = 'sys' and last_analyze IS NOT NULL)
GO


-- will return null as all of the catalog has been analyzed during extension create
SELECT * FROM auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
GO
11 changes: 11 additions & 0 deletions test/JDBC/input/AUTO_ANALYZE-vu-verify.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@

-- list all the babelfish catalogs that has not been analyzed manually after upgrade
-- will return null
SELECT * FROM auto_analyze_vu_prepare_catalogs_have_not_been_analyzed()
GO

DROP FUNCTION auto_analyze_vu_prepare_catalogs_have_not_been_analyzed
GO

DROP FUNCTION auto_analyze_vu_prepare_catalogs_have_been_analyzed
GO
2 changes: 1 addition & 1 deletion test/JDBC/input/openquery_upgrd_before_15_4-vu-prepare.mix
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@ EXEC sp_serveroption @server='bbf_server_2', @optname='connect timeout', @optval
GO

-- check if the linked servers added above are reflected in babelfish_server_options catalog
SELECT servername, query_timeout, connect_timeout FROM babelfish_server_options WHERE servername = 'bbf_server' OR servername = 'bbf_server_1' OR servername = 'bbf_server_2'
SELECT servername, query_timeout, connect_timeout FROM babelfish_server_options WHERE servername = 'bbf_server' OR servername = 'bbf_server_1' OR servername = 'bbf_server_2' order by servername
GO

-- Create a view dependent on OPENQUERY
Expand Down
2 changes: 2 additions & 0 deletions test/JDBC/jdbc_schedule
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,8 @@ ignore#!#forjson-subquery-before-14_10-or-15_5-vu-cleanup
ignore#!#forjson-datatypes-before-14_10-or-15_5-vu-prepare
ignore#!#forjson-datatypes-before-14_10-or-15_5-vu-verify
ignore#!#forjson-datatypes-before-14_10-or-15_5-vu-cleanup
ignore#!#AUTO_ANALYZE-before-15-5-or-14-10-vu-prepare
ignore#!#AUTO_ANALYZE-before-15-5-or-14-10-vu-verify
ignore#!#orderby-before-15_3-vu-prepare
ignore#!#orderby-before-15_3-vu-verify
ignore#!#orderby-before-15_3-vu-cleanup
Expand Down
3 changes: 2 additions & 1 deletion test/JDBC/upgrade/13_4/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -215,4 +215,5 @@ TestXML
timefromparts
triggers_with_transaction
BABEL-4046
getdate
getdate
AUTO_ANALYZE-before-15-5-or-14-10
3 changes: 2 additions & 1 deletion test/JDBC/upgrade/13_5/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -268,4 +268,5 @@ TestXML
timefromparts
triggers_with_transaction
BABEL-4046
getdate
getdate
AUTO_ANALYZE-before-15-5-or-14-10
1 change: 1 addition & 0 deletions test/JDBC/upgrade/13_6/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -325,3 +325,4 @@ BABEL-4046
getdate
BABEL-4410
GRANT_SCHEMA
AUTO_ANALYZE-before-15-5-or-14-10
3 changes: 2 additions & 1 deletion test/JDBC/upgrade/13_7/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -316,4 +316,5 @@ TestXML
timefromparts
triggers_with_transaction
BABEL-4046
getdate
getdate
AUTO_ANALYZE-before-15-5-or-14-10
3 changes: 2 additions & 1 deletion test/JDBC/upgrade/13_8/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -316,4 +316,5 @@ TestXML
timefromparts
triggers_with_transaction
BABEL-4046
getdate
getdate
AUTO_ANALYZE-before-15-5-or-14-10
1 change: 1 addition & 0 deletions test/JDBC/upgrade/13_9/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -321,3 +321,4 @@ BABEL-4046
getdate
BABEL-4410
GRANT_SCHEMA
AUTO_ANALYZE-before-15-5-or-14-10
3 changes: 2 additions & 1 deletion test/JDBC/upgrade/14_3/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -338,4 +338,5 @@ BABEL-4046
BABEL_4330
BABEL-2619
BABEL-4410
GRANT_SCHEMA
GRANT_SCHEMA
AUTO_ANALYZE-before-15-5-or-14-10
1 change: 1 addition & 0 deletions test/JDBC/upgrade/14_5/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -354,3 +354,4 @@ BABEL_4330
BABEL-2619
BABEL-4410
GRANT_SCHEMA
AUTO_ANALYZE-before-15-5-or-14-10
1 change: 1 addition & 0 deletions test/JDBC/upgrade/14_6/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -388,3 +388,4 @@ BABEL_4330
BABEL-2619
BABEL-4410
GRANT_SCHEMA
AUTO_ANALYZE-before-15-5-or-14-10
3 changes: 2 additions & 1 deletion test/JDBC/upgrade/14_7/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -407,4 +407,5 @@ datetimeoffset-timezone-before-15_3
BABEL-4046
getdate
BABEL_4330
BABEL-2619
BABEL-2619
AUTO_ANALYZE-before-15-5-or-14-10
3 changes: 2 additions & 1 deletion test/JDBC/upgrade/14_8/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -405,4 +405,5 @@ datetimeoffset-timezone-before-15_3
BABEL-4046
getdate
BABEL_4330
BABEL-2619
BABEL-2619
AUTO_ANALYZE-before-15-5-or-14-10
1 change: 1 addition & 0 deletions test/JDBC/upgrade/14_9/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -408,3 +408,4 @@ getdate
BABEL_4330
BABEL-2619
BABEL-4410
AUTO_ANALYZE-before-15-5-or-14-10
3 changes: 2 additions & 1 deletion test/JDBC/upgrade/15_1/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -384,4 +384,5 @@ timefromparts
triggers_with_transaction
BABEL-4046
getdate
BABEL_4330
BABEL_4330
AUTO_ANALYZE-before-15-5-or-14-10
1 change: 1 addition & 0 deletions test/JDBC/upgrade/15_2/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -416,3 +416,4 @@ getdate
BABEL_4330
BABEL-4410
GRANT_SCHEMA
AUTO_ANALYZE-before-15-5-or-14-10
1 change: 1 addition & 0 deletions test/JDBC/upgrade/15_3/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -437,3 +437,4 @@ datetimeoffset-timezone
BABEL-4046
getdate
BABEL_4330
AUTO_ANALYZE-before-15-5-or-14-10
1 change: 1 addition & 0 deletions test/JDBC/upgrade/15_4/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -450,3 +450,4 @@ sp_who
BABEL_4330
BABEL-4410
GRANT_SCHEMA
AUTO_ANALYZE-before-15-5-or-14-10
1 change: 1 addition & 0 deletions test/JDBC/upgrade/latest/schedule
Original file line number Diff line number Diff line change
Expand Up @@ -474,3 +474,4 @@ sys_certificates
sys_database_permissions
BABEL-4279
BABEL-4484
#AUTO_ANALYZE #uncomment this test when preparing for new minor version
sumitj824 marked this conversation as resolved.
Show resolved Hide resolved
Loading