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 19 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
27 changes: 21 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 @@ -4244,11 +4244,19 @@ tsql_IsolationLevelStr:
}
| REPEATABLE READ
{
TSQLInstrumentation(INSTR_UNSUPPORTED_TSQL_ISOLATION_LEVEL_REPEATABLE_READ);
ereport(ERROR,
if(pltsql_enable_repeatable_read_isolation_level)
{
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 isolation level is not supported, consider setting babelfishpg_tsql.enable_repeatable_read_isolation_level to on"),
parser_errposition(@1)));
}

}
| SNAPSHOT
{
Expand All @@ -4257,11 +4265,18 @@ tsql_IsolationLevelStr:
}
| SERIALIZABLE
{
TSQLInstrumentation(INSTR_UNSUPPORTED_TSQL_ISOLATION_LEVEL_SERIALIZABLE);
ereport(ERROR,
if(pltsql_enable_serializable_isolation_level)
{
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 isolation level is not supported, consider setting babelfishpg_tsql.enable_serializable_isolation_level to on"),
parser_errposition(@1)));
}
}
;

Expand Down
20 changes: 20 additions & 0 deletions contrib/babelfishpg_tsql/src/guc.c
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,8 @@ 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
bool pltsql_enable_repeatable_read_isolation_level = false;
bool pltsql_enable_serializable_isolation_level = false;

static const struct config_enum_entry explain_format_options[] = {
{"text", EXPLAIN_FORMAT_TEXT, false},
Expand Down Expand Up @@ -1173,6 +1175,24 @@ define_custom_variables(void)
PGC_SUSET,
GUC_NO_SHOW_ALL | GUC_NOT_IN_SAMPLE | GUC_DISALLOW_IN_AUTO_FILE,
NULL, NULL, NULL);

DefineCustomBoolVariable("babelfishpg_tsql.enable_repeatable_read_isolation_level",
gettext_noop("Enables support for isolation level reapeatable read"),
NULL,
&pltsql_enable_repeatable_read_isolation_level,
false,
PGC_USERSET,
GUC_NO_SHOW_ALL | GUC_NOT_IN_SAMPLE | GUC_DISALLOW_IN_AUTO_FILE,
NULL, NULL, NULL);

DefineCustomBoolVariable("babelfishpg_tsql.enable_serializable_isolation_level",
gettext_noop("Enables support for isolation level serializable"),
NULL,
&pltsql_enable_serializable_isolation_level,
false,
PGC_USERSET,
GUC_NO_SHOW_ALL | GUC_NOT_IN_SAMPLE | GUC_DISALLOW_IN_AUTO_FILE,
NULL, NULL, NULL);
}

int escape_hatch_storage_options = EH_IGNORE;
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 bool pltsql_enable_repeatable_read_isolation_level;
extern bool pltsql_enable_serializable_isolation_level;

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 isolation level is not supported, consider setting babelfishpg_tsql.enable_repeatable_read_isolation_level to on)~~

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 isolation level is not supported, consider setting babelfishpg_tsql.enable_serializable_isolation_level to on)~~

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.enable_repeatable_read_isolation_level','on',false);
SELECT SET_CONFIG('babelfishpg_tsql.enable_serializable_isolation_level','on',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
on
~~END~~

~~START~~
text
on
~~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~~

Loading