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

Support repeatable read and serializable isolation level #1695

Merged
Merged
Show file tree
Hide file tree
Changes from 30 commits
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
24b2488
fix: add support to handle reapeatable read isolation level as snapshot
Aug 8, 2023
7f9fb25
fix: update error message for SET repeatable read in test output files
Aug 8, 2023
fbde49d
fix: test out error message for set isolation level
Aug 8, 2023
d110850
fix: handle serializable isolation level as snapshot isolation level …
Aug 10, 2023
1df807a
test: add test cases for concurrent update/delete
Aug 11, 2023
8cc852d
test: add JDBC tests for setting isolation levels
Aug 11, 2023
33ba846
test: add jdbc test for setting guc on database/session level
Aug 14, 2023
a987487
fix: remove some concurrent isolation tests
Aug 14, 2023
0e9e058
Empty-Commit
Aug 15, 2023
4e58f32
fix: change apping for serializable level
Aug 17, 2023
086796f
Empty commit
tanscorpio7 Aug 17, 2023
f7fddc5
refactor: change guc name
tanscorpio7 Aug 21, 2023
e9a3d93
refactor: change error message
tanscorpio7 Aug 21, 2023
b14a5d7
refactor: change description for guc
tanscorpio7 Aug 21, 2023
5d637ad
fix: separate gucs for isolation levels
tanscorpio7 Aug 22, 2023
142e467
fix: add test for phantomn read in repeatable read
tanscorpio7 Aug 22, 2023
6fd9432
fix: fix python tests for serializable
tanscorpio7 Aug 23, 2023
0d9107c
refactor
tanscorpio7 Aug 24, 2023
4757a79
empty commit to add signoff in PR
tanscorpio7 Aug 25, 2023
8fb83d2
fix: add dotnet test for isolation levels
tanscorpio7 Aug 28, 2023
106a5cd
Merge branch 'BABEL_3_X_DEV' into BABEL_4146
tanscorpio7 Oct 19, 2023
c18a168
refactor guc names
tanscorpio7 Oct 19, 2023
789236c
update guc name in tests
tanscorpio7 Oct 19, 2023
57f84b9
retrigger tests
tanscorpio7 Oct 19, 2023
52a5023
retrigger tests
tanscorpio7 Oct 19, 2023
9a1360d
remove 4145 from parallel worker
tanscorpio7 Oct 19, 2023
77f1fac
add isolation gucs to sp_babelfish_configure
tanscorpio7 Oct 19, 2023
f6c8f07
add sp_configurations_view to upgrade script
tanscorpio7 Oct 20, 2023
d351911
indentation
tanscorpio7 Oct 21, 2023
70cba7a
indentation
tanscorpio7 Oct 21, 2023
0f34fe6
use enum GUC & refactor guc name and err msg
tanscorpio7 Oct 23, 2023
c387ad7
refactor
tanscorpio7 Oct 25, 2023
ce3e97c
refactor
tanscorpio7 Oct 25, 2023
48356da
fix typo
tanscorpio7 Oct 25, 2023
809c958
Merge branch 'BABEL_3_X_DEV' into BABEL_4146
tanscorpio7 Oct 25, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion contrib/babelfishpg_tsql/sql/sys_procedures.sql
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,9 @@ CREATE VIEW sys.babelfish_configurations_view as
FROM pg_catalog.pg_settings
WHERE name collate "C" like 'babelfishpg_tsql.explain_%' OR
name collate "C" like 'babelfishpg_tsql.escape_hatch_%' OR
name collate "C" = 'babelfishpg_tsql.enable_pg_hint';
name collate "C" = 'babelfishpg_tsql.enable_pg_hint' OR
name collate "C" = 'babelfishpg_tsql.repeatable_read_isolation' OR
tanscorpio7 marked this conversation as resolved.
Show resolved Hide resolved
name collate "C" = 'babelfishpg_tsql.serializable_isolation';
GRANT SELECT on sys.babelfish_configurations_view TO PUBLIC;

CREATE OR REPLACE PROCEDURE sys.sp_babelfish_configure(IN "@option_name" varchar(128), IN "@option_value" varchar(128), IN "@option_scope" varchar(128))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1341,6 +1341,15 @@ 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);

CREATE OR REPLACE VIEW sys.babelfish_configurations_view as
SELECT *
FROM pg_catalog.pg_settings
WHERE name collate "C" like 'babelfishpg_tsql.explain_%' OR
name collate "C" like 'babelfishpg_tsql.escape_hatch_%' OR
name collate "C" = 'babelfishpg_tsql.enable_pg_hint' OR
name collate "C" = 'babelfishpg_tsql.repeatable_read_isolation' OR
name collate "C" = 'babelfishpg_tsql.serializable_isolation';
GRANT SELECT on sys.babelfish_configurations_view TO PUBLIC;

-- Reset search_path to not affect any subsequent scripts
SELECT set_config('search_path', trim(leading 'sys, ' from current_setting('search_path')), false);
29 changes: 23 additions & 6 deletions contrib/babelfishpg_tsql/src/backend_parser/gram-tsql-rule.y
Original file line number Diff line number Diff line change
Expand Up @@ -4338,11 +4338,20 @@ tsql_IsolationLevelStr:
}
| REPEATABLE READ
{
TSQLInstrumentation(INSTR_UNSUPPORTED_TSQL_ISOLATION_LEVEL_REPEATABLE_READ);
ereport(ERROR,
if (strcmp(pltsql_repeatable_read_isolation, "pg_isolation") == 0)
tanscorpio7 marked this conversation as resolved.
Show resolved Hide resolved
{
TSQLInstrumentation(INSTR_TSQL_ISOLATION_LEVEL_REPEATABLE_READ);
$$ = "repeatable read";
}
else
{
TSQLInstrumentation(INSTR_UNSUPPORTED_TSQL_ISOLATION_LEVEL_REPEATABLE_READ);
ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("REPEATABLE READ isolation level is not supported"),
errmsg("Repeatable read is not supported by default, set configuration parameter 'repeatable_read_isolation' to 'pg_isolation' to get PG repeatable read"),
tanscorpio7 marked this conversation as resolved.
Show resolved Hide resolved
parser_errposition(@1)));
}

}
| SNAPSHOT
{
Expand All @@ -4351,11 +4360,19 @@ tsql_IsolationLevelStr:
}
| SERIALIZABLE
{
TSQLInstrumentation(INSTR_UNSUPPORTED_TSQL_ISOLATION_LEVEL_SERIALIZABLE);
ereport(ERROR,
if (strcmp(pltsql_serializable_isolation, "pg_isolation") == 0)
{
TSQLInstrumentation(INSTR_TSQL_ISOLATION_LEVEL_SERIALIZABLE);
$$ = "serializable";
}
else
{
TSQLInstrumentation(INSTR_UNSUPPORTED_TSQL_ISOLATION_LEVEL_SERIALIZABLE);
ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("SERIALIZABLE isolation level is not supported"),
errmsg("Serializable is not supported by default, set configuration parameter 'serializable_isolation' to 'pg_isolation' to get PG serializable"),
tanscorpio7 marked this conversation as resolved.
Show resolved Hide resolved
parser_errposition(@1)));
}
}
;

Expand Down
33 changes: 31 additions & 2 deletions contrib/babelfishpg_tsql/src/guc.c
Original file line number Diff line number Diff line change
Expand Up @@ -61,12 +61,13 @@ bool pltsql_showplan_xml = false;
bool pltsql_fmtonly = false;
bool pltsql_enable_tsql_information_schema = true;
bool pltsql_no_browsetable = false;
bool pltsql_enable_create_alter_view_from_pg = false;

char *pltsql_host_destribution = NULL;
char *pltsql_host_release = NULL;
char *pltsql_host_service_pack_level = NULL;

bool pltsql_enable_create_alter_view_from_pg = false;
tanscorpio7 marked this conversation as resolved.
Show resolved Hide resolved
char *pltsql_repeatable_read_isolation = NULL;
char *pltsql_serializable_isolation = NULL;

static const struct config_enum_entry explain_format_options[] = {
{"text", EXPLAIN_FORMAT_TEXT, false},
Expand Down Expand Up @@ -390,6 +391,16 @@ check_tsql_version(char **newval, void **extra, GucSource source)
return true;
}

static bool
check_bbf_isolation_type(char **newval, void **extra, GucSource source)
{
if (pg_strcasecmp(*newval, "pg_isolation") != 0 &&
pg_strcasecmp(*newval, "default") != 0)
return false;

return true;
}

static void
assign_enable_pg_hint(bool newval, void *extra)
{
Expand Down Expand Up @@ -805,6 +816,24 @@ define_custom_variables(void)
PGC_USERSET,
GUC_NOT_IN_SAMPLE | GUC_NO_SHOW_ALL | GUC_NO_RESET_ALL | GUC_DISALLOW_IN_FILE | GUC_DISALLOW_IN_AUTO_FILE,
NULL, NULL, NULL);

DefineCustomStringVariable("babelfishpg_tsql.repeatable_read_isolation",
tanscorpio7 marked this conversation as resolved.
Show resolved Hide resolved
gettext_noop("Select mapping for isolation level reapeatable read"),
NULL,
&pltsql_repeatable_read_isolation,
"default",
PGC_USERSET,
GUC_NOT_IN_SAMPLE | GUC_DISALLOW_IN_FILE | GUC_DISALLOW_IN_AUTO_FILE,
check_bbf_isolation_type, NULL, NULL);

DefineCustomStringVariable("babelfishpg_tsql.serializable_isolation",
gettext_noop("Select mapping for isolation level serializable"),
NULL,
&pltsql_serializable_isolation,
"default",
PGC_USERSET,
GUC_NOT_IN_SAMPLE | GUC_DISALLOW_IN_FILE | GUC_DISALLOW_IN_AUTO_FILE,
check_bbf_isolation_type, NULL, NULL);

DefineCustomIntVariable("babelfishpg_tsql.datefirst",
gettext_noop("Sets the first day of the week to a number from 1 through 7."),
Expand Down
2 changes: 2 additions & 0 deletions contrib/babelfishpg_tsql/src/guc.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ extern bool pltsql_enable_create_alter_view_from_pg;
extern bool pltsql_enable_linked_servers;
extern bool pltsql_allow_windows_login;
extern char *pltsql_psql_logical_babelfish_db_name;
extern char *pltsql_repeatable_read_isolation;
extern char *pltsql_serializable_isolation;

extern void define_custom_variables(void);
extern void pltsql_validate_set_config_function(char *name, char *value);
Expand Down
2 changes: 2 additions & 0 deletions contrib/babelfishpg_tsql/src/pltsql_instr.h
Original file line number Diff line number Diff line change
Expand Up @@ -632,8 +632,10 @@ typedef enum PgTsqlInstrMetricType

INSTR_TSQL_ISOLATION_LEVEL_READ_UNCOMMITTED,
INSTR_TSQL_ISOLATION_LEVEL_READ_COMMITTED,
INSTR_TSQL_ISOLATION_LEVEL_REPEATABLE_READ,
INSTR_UNSUPPORTED_TSQL_ISOLATION_LEVEL_REPEATABLE_READ,
INSTR_TSQL_ISOLATION_LEVEL_SNAPSHOT,
INSTR_TSQL_ISOLATION_LEVEL_SERIALIZABLE,
INSTR_UNSUPPORTED_TSQL_ISOLATION_LEVEL_SERIALIZABLE,

INSTR_UNSUPPORTED_TSQL_SELECT_COL_ALIAS,
Expand Down
93 changes: 91 additions & 2 deletions test/JDBC/expected/BABEL-3214.out
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
GO
~~ERROR (Code: 33557097)~~

~~ERROR (Message: REPEATABLE READ isolation level is not supported)~~
~~ERROR (Message: Repeatable read is not supported by default, set configuration parameter 'repeatable_read_isolation' to 'pg_isolation' to get PG repeatable read)~~

SELECT CAST(current_setting('transaction_isolation') AS VARCHAR);
SELECT transaction_isolation_level from sys.dm_exec_sessions WHERE session_id = @@SPID;
Expand All @@ -65,7 +65,7 @@ SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
GO
~~ERROR (Code: 33557097)~~

~~ERROR (Message: SERIALIZABLE isolation level is not supported)~~
~~ERROR (Message: Serializable is not supported by default, set configuration parameter 'serializable_isolation' to 'pg_isolation' to get PG serializable)~~

SELECT CAST(current_setting('transaction_isolation') AS VARCHAR);
SELECT transaction_isolation_level from sys.dm_exec_sessions WHERE session_id = @@SPID;
Expand Down Expand Up @@ -98,3 +98,92 @@ smallint
5
~~END~~


SELECT set_config('babelfishpg_tsql.repeatable_read_isolation','pg_isolation',false);
SELECT set_config('babelfishpg_tsql.serializable_isolation','pg_isolation',false);
SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
SELECT CAST(current_setting('transaction_isolation') AS VARCHAR);
SELECT transaction_isolation_level from sys.dm_exec_sessions WHERE session_id = @@SPID;
GO
~~START~~
text
pg_isolation
~~END~~

~~START~~
text
pg_isolation
~~END~~

~~START~~
varchar
read uncommitted
~~END~~

~~START~~
smallint
1
~~END~~


SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
SELECT CAST(current_setting('transaction_isolation') AS VARCHAR);
SELECT transaction_isolation_level from sys.dm_exec_sessions WHERE session_id = @@SPID;
GO
~~START~~
varchar
read committed
~~END~~

~~START~~
smallint
2
~~END~~


SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
GO
SELECT CAST(current_setting('transaction_isolation') AS VARCHAR);
SELECT transaction_isolation_level from sys.dm_exec_sessions WHERE session_id = @@SPID;
GO
~~START~~
varchar
repeatable read
~~END~~

~~START~~
smallint
5
~~END~~


SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
GO
SELECT CAST(current_setting('transaction_isolation') AS VARCHAR);
SELECT transaction_isolation_level from sys.dm_exec_sessions WHERE session_id = @@SPID;
GO
~~START~~
varchar
serializable
~~END~~

~~START~~
smallint
4
~~END~~


SET TRANSACTION ISOLATION LEVEL SNAPSHOT;
SELECT CAST(current_setting('transaction_isolation') AS VARCHAR);
SELECT transaction_isolation_level from sys.dm_exec_sessions WHERE session_id = @@SPID;
GO
~~START~~
varchar
repeatable read
~~END~~

~~START~~
smallint
5
~~END~~

6 changes: 6 additions & 0 deletions test/JDBC/expected/BABEL-UNSUPPORTED.out
Original file line number Diff line number Diff line change
Expand Up @@ -2035,6 +2035,8 @@ babelfishpg_tsql.explain_summary#!#on#!#Include summary information (e.g., total
babelfishpg_tsql.explain_timing#!#on#!#Include actual startup time and time spent in each node in the output
babelfishpg_tsql.explain_verbose#!#off#!#Display additional information regarding the plan
babelfishpg_tsql.explain_wal#!#off#!#Include information on WAL record generation
babelfishpg_tsql.repeatable_read_isolation#!#default#!#Select mapping for isolation level reapeatable read
babelfishpg_tsql.serializable_isolation#!#default#!#Select mapping for isolation level serializable
~~END~~


Expand Down Expand Up @@ -2101,6 +2103,8 @@ babelfishpg_tsql.explain_summary#!#on#!#Include summary information (e.g., total
babelfishpg_tsql.explain_timing#!#on#!#Include actual startup time and time spent in each node in the output
babelfishpg_tsql.explain_verbose#!#off#!#Display additional information regarding the plan
babelfishpg_tsql.explain_wal#!#off#!#Include information on WAL record generation
babelfishpg_tsql.repeatable_read_isolation#!#default#!#Select mapping for isolation level reapeatable read
babelfishpg_tsql.serializable_isolation#!#default#!#Select mapping for isolation level serializable
~~END~~


Expand Down Expand Up @@ -2148,6 +2152,8 @@ babelfishpg_tsql.explain_summary#!#on#!#Include summary information (e.g., total
babelfishpg_tsql.explain_timing#!#on#!#Include actual startup time and time spent in each node in the output
babelfishpg_tsql.explain_verbose#!#off#!#Display additional information regarding the plan
babelfishpg_tsql.explain_wal#!#off#!#Include information on WAL record generation
babelfishpg_tsql.repeatable_read_isolation#!#default#!#Select mapping for isolation level reapeatable read
babelfishpg_tsql.serializable_isolation#!#default#!#Select mapping for isolation level serializable
~~END~~


Expand Down
Loading
Loading