From d7985ee05e4eef4b56eaec109aa9d79423ac54aa Mon Sep 17 00:00:00 2001 From: Deepakshi Mittal <78574784+deepakshi-mittal@users.noreply.github.com> Date: Tue, 28 Nov 2023 13:21:26 -0800 Subject: [PATCH] Revert "Support for Instead of Trigger On Views in Babelfish (#1876)" (#2070) This reverts commit fc41222c705a5c330f0c2e8c4ac66eb2584de8b6. --- contrib/babelfishpg_tsql/src/hooks.c | 38 -- test/JDBC/expected/BABEL-2170-vu-cleanup.out | 39 -- test/JDBC/expected/BABEL-2170-vu-prepare.out | 105 ---- test/JDBC/expected/BABEL-2170-vu-verify.out | 578 ------------------ .../input/triggers/BABEL-2170-vu-cleanup.sql | 39 -- .../input/triggers/BABEL-2170-vu-prepare.sql | 93 --- .../input/triggers/BABEL-2170-vu-verify.sql | 321 ---------- test/JDBC/upgrade/latest/schedule | 1 - 8 files changed, 1214 deletions(-) delete mode 100644 test/JDBC/expected/BABEL-2170-vu-cleanup.out delete mode 100644 test/JDBC/expected/BABEL-2170-vu-prepare.out delete mode 100644 test/JDBC/expected/BABEL-2170-vu-verify.out delete mode 100644 test/JDBC/input/triggers/BABEL-2170-vu-cleanup.sql delete mode 100644 test/JDBC/input/triggers/BABEL-2170-vu-prepare.sql delete mode 100644 test/JDBC/input/triggers/BABEL-2170-vu-verify.sql diff --git a/contrib/babelfishpg_tsql/src/hooks.c b/contrib/babelfishpg_tsql/src/hooks.c index b0f955b5d5..bbd9fef7de 100644 --- a/contrib/babelfishpg_tsql/src/hooks.c +++ b/contrib/babelfishpg_tsql/src/hooks.c @@ -158,7 +158,6 @@ static void pltsql_ExecutorStart(QueryDesc *queryDesc, int eflags); static void pltsql_ExecutorRun(QueryDesc *queryDesc, ScanDirection direction, uint64 count, bool execute_once); static void pltsql_ExecutorFinish(QueryDesc *queryDesc); static void pltsql_ExecutorEnd(QueryDesc *queryDesc); -static bool pltsql_bbfViewHasInsteadofTrigger(Relation view, CmdType event); static bool plsql_TriggerRecursiveCheck(ResultRelInfo *resultRelInfo); static bool bbf_check_rowcount_hook(int es_processed); @@ -210,7 +209,6 @@ static ExecutorFinish_hook_type prev_ExecutorFinish = NULL; static ExecutorEnd_hook_type prev_ExecutorEnd = NULL; static GetNewObjectId_hook_type prev_GetNewObjectId_hook = NULL; static inherit_view_constraints_from_table_hook_type prev_inherit_view_constraints_from_table = NULL; -static bbfViewHasInsteadofTrigger_hook_type prev_bbfViewHasInsteadofTrigger_hook = NULL; static detect_numeric_overflow_hook_type prev_detect_numeric_overflow_hook = NULL; static match_pltsql_func_call_hook_type prev_match_pltsql_func_call_hook = NULL; static insert_pltsql_function_defaults_hook_type prev_insert_pltsql_function_defaults_hook = NULL; @@ -327,9 +325,6 @@ InstallExtendedHooks(void) inherit_view_constraints_from_table_hook = preserve_view_constraints_from_base_table; TriggerRecuresiveCheck_hook = plsql_TriggerRecursiveCheck; - prev_bbfViewHasInsteadofTrigger_hook = bbfViewHasInsteadofTrigger_hook; - bbfViewHasInsteadofTrigger_hook = pltsql_bbfViewHasInsteadofTrigger; - prev_detect_numeric_overflow_hook = detect_numeric_overflow_hook; detect_numeric_overflow_hook = pltsql_detect_numeric_overflow; @@ -445,7 +440,6 @@ UninstallExtendedHooks(void) ExecutorEnd_hook = prev_ExecutorEnd; GetNewObjectId_hook = prev_GetNewObjectId_hook; inherit_view_constraints_from_table_hook = prev_inherit_view_constraints_from_table; - bbfViewHasInsteadofTrigger_hook = prev_bbfViewHasInsteadofTrigger_hook; detect_numeric_overflow_hook = prev_detect_numeric_overflow_hook; match_pltsql_func_call_hook = prev_match_pltsql_func_call_hook; insert_pltsql_function_defaults_hook = prev_insert_pltsql_function_defaults_hook; @@ -725,38 +719,6 @@ plsql_TriggerRecursiveCheck(ResultRelInfo *resultRelInfo) return false; } -/** - * Hook function to skip rewriting VIEW with base table if the VIEW has an instead of trigger - * Checks if view have an INSTEAD OF trigger at statement level - * If it does, we don't want to treat it as auto-updatable. - * Reference - src/backend/rewrite/rewriteHandler.c view_has_instead_trigger -*/ -static bool -pltsql_bbfViewHasInsteadofTrigger(Relation view, CmdType event) -{ - TriggerDesc *trigDesc = view->trigdesc; - - switch (event) - { - case CMD_INSERT: - if(trigDesc && trigDesc->trig_insert_instead_statement) - return true; - break; - case CMD_UPDATE: - if (trigDesc && trigDesc->trig_update_instead_statement) - return true; - break; - case CMD_DELETE: - if (trigDesc && trigDesc->trig_delete_instead_statement) - return true; - break; - default: - elog(ERROR, "unrecognized CmdType: %d", (int) event); - break; - } - return false; -} - /* * Wrapper function that calls the initilization function. * Calls the pre function call hook on the procname diff --git a/test/JDBC/expected/BABEL-2170-vu-cleanup.out b/test/JDBC/expected/BABEL-2170-vu-cleanup.out deleted file mode 100644 index 9fd916b30f..0000000000 --- a/test/JDBC/expected/BABEL-2170-vu-cleanup.out +++ /dev/null @@ -1,39 +0,0 @@ --- clean all objects in first database -USE db1_BABEL2170; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_insert; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_update; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_delete; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_bulkinsert; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view_bulkinsert; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view_2; -GO - -DROP TABLE IF EXISTS babel_2170_vu_employees; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view_txn; -GO - -DROP TABLE IF EXISTS babel_2170_vu_employees_txn; -GO - -USE MASTER; -GO - -DROP DATABASE IF EXISTS db1_BABEL2170; -GO diff --git a/test/JDBC/expected/BABEL-2170-vu-prepare.out b/test/JDBC/expected/BABEL-2170-vu-prepare.out deleted file mode 100644 index dc6cd1a8cc..0000000000 --- a/test/JDBC/expected/BABEL-2170-vu-prepare.out +++ /dev/null @@ -1,105 +0,0 @@ --- We will create two databases db1_BABEL2170, db2_BABEL2170 -CREATE DATABASE db1_BABEL2170; -GO - -USE db1_BABEL2170; -GO - -CREATE TABLE babel_2170_vu_employees -( - EmployeeID int NOT NULL, - EmployeeName VARCHAR(50), - EmployeeAddress VARCHAR(50), - MonthSalary NUMERIC(10, 2) -) -GO - -INSERT INTO babel_2170_vu_employees VALUES(1, 'amber', '1st Street', '1000'); -INSERT INTO babel_2170_vu_employees VALUES(2, 'angel', '1st Street', '2000'); -GO -~~ROW COUNT: 1~~ - -~~ROW COUNT: 1~~ - - -CREATE VIEW babel_2170_vu_employees_view AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees -WHERE EmployeeName LIKE 'a%'; -GO - -CREATE VIEW babel_2170_vu_employees_view_bulkinsert AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees -WHERE EmployeeName LIKE 'b%'; -GO - -CREATE VIEW babel_2170_vu_employees_view_2 AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees -WHERE EmployeeName LIKE 'a%'; -GO - -CREATE SCHEMA schema_2170; -GO - -CREATE TABLE schema_2170.babel_2170_vu_employees -( - EmployeeID int NOT NULL, - EmployeeName VARCHAR(50), - EmployeeAddress VARCHAR(50), - MonthSalary NUMERIC(10, 2) -) -GO - -INSERT INTO schema_2170.babel_2170_vu_employees VALUES(1, 'amber', '1st Street', '1000'); -INSERT INTO schema_2170.babel_2170_vu_employees VALUES(2, 'angel', '1st Street', '2000'); -GO -~~ROW COUNT: 1~~ - -~~ROW COUNT: 1~~ - - -CREATE VIEW schema_2170.babel_2170_vu_employees_view AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM schema_2170.babel_2170_vu_employees -WHERE EmployeeName LIKE 'a%'; -GO - -CREATE TABLE babel_2170_vu_employees_txn -( - EmployeeID int NOT NULL, - EmployeeName VARCHAR(50), - EmployeeAddress VARCHAR(50), - MonthSalary NUMERIC(10, 2) -) -GO - -INSERT INTO babel_2170_vu_employees_txn VALUES(1, 'amber', '1st Street', '1000'); -INSERT INTO babel_2170_vu_employees_txn VALUES(2, 'angel', '1st Street', '2000'); -GO -~~ROW COUNT: 1~~ - -~~ROW COUNT: 1~~ - - -CREATE VIEW babel_2170_vu_employees_view_txn AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees_txn -WHERE EmployeeName LIKE 'a%'; -GO diff --git a/test/JDBC/expected/BABEL-2170-vu-verify.out b/test/JDBC/expected/BABEL-2170-vu-verify.out deleted file mode 100644 index 94e3ee9a16..0000000000 --- a/test/JDBC/expected/BABEL-2170-vu-verify.out +++ /dev/null @@ -1,578 +0,0 @@ -USE db1_BABEL2170; -GO - --- Instead of Insert Trigger on View -CREATE TRIGGER babel_2170_vu_employees_view_iot_insert ON babel_2170_vu_employees_view -INSTEAD OF INSERT -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_insert Invoked' -END -GO - -INSERT INTO babel_2170_vu_employees_view VALUES(3, 'adam', '1st Street', '3000'); -GO -~~START~~ -varchar -Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_insert Invoked -~~END~~ - -~~ROW COUNT: 1~~ - - -SELECT COUNT(EmployeeID) FROM babel_2170_vu_employees; -GO -~~START~~ -int -2 -~~END~~ - - -SELECT COUNT(EmployeeID) FROM babel_2170_vu_employees_view; -GO -~~START~~ -int -2 -~~END~~ - - --- Instead of Update Trigger on View -CREATE TRIGGER babel_2170_vu_employees_view_iot_update ON babel_2170_vu_employees_view -INSTEAD OF UPDATE -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_update Invoked' -END -GO - -UPDATE babel_2170_vu_employees_view SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO -~~START~~ -varchar -Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_update Invoked -~~END~~ - -~~ROW COUNT: 1~~ - - -SELECT EmployeeID,EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees WHERE EmployeeID = 2 ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -2#!#angel#!#1st Street#!#2000.00 -~~END~~ - - -BEGIN TRANSACTION - UPDATE babel_2170_vu_employees_view SET MonthSalary = MonthSalary +1 WHERE EmployeeID IN (1, 2); -COMMIT TRANSACTION; -GO -~~START~~ -varchar -Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_update Invoked -~~END~~ - -~~ROW COUNT: 2~~ - - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees WHERE EmployeeID IN (1, 2) ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2000.00 -~~END~~ - - --- Instead of Delete Trigger on View -CREATE TRIGGER babel_2170_vu_employees_view_iot_delete ON babel_2170_vu_employees_view -INSTEAD OF DELETE -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_delete Invoked' -END -GO - -BEGIN TRANSACTION - DELETE FROM babel_2170_vu_employees_view WHERE EmployeeID IN (1, 2); -COMMIT TRANSACTION; -GO -~~START~~ -varchar -Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_delete Invoked -~~END~~ - -~~ROW COUNT: 2~~ - - -SELECT COUNT(EmployeeID) FROM babel_2170_vu_employees_view; -GO -~~START~~ -int -2 -~~END~~ - - -SELECT COUNT(EmployeeID) FROM babel_2170_vu_employees; -GO -~~START~~ -int -2 -~~END~~ - - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2000.00 -~~END~~ - - ---- Tests multiple insert queries and check if inserted table can be accessed and trigger is working fine. -CREATE TRIGGER babel_2170_vu_employees_view_iot_bulkinsert ON babel_2170_vu_employees_view_bulkinsert -INSTEAD OF INSERT -AS - SELECT * FROM INSERTED; -GO - -BEGIN TRANSACTION -DECLARE @i int = 1 - WHILE @i <= 3 - BEGIN - INSERT INTO babel_2170_vu_employees_view_bulkinsert VALUES(@i, 'bob', '1st Street', '1000'); - SET @i = @i + 1 - END -COMMIT TRANSACTION -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#bob#!#1st Street#!#1000.00 -~~END~~ - -~~ROW COUNT: 1~~ - -~~START~~ -int#!#varchar#!#varchar#!#numeric -2#!#bob#!#1st Street#!#1000.00 -~~END~~ - -~~ROW COUNT: 1~~ - -~~START~~ -int#!#varchar#!#varchar#!#numeric -3#!#bob#!#1st Street#!#1000.00 -~~END~~ - -~~ROW COUNT: 1~~ - - --- Same trigger name on different View created on Same table in same schema -CREATE TRIGGER babel_2170_vu_employees_view_iot_update ON babel_2170_vu_employees_view_2 -INSTEAD OF INSERT -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view2_iot_update Invoked' -END -GO -~~ERROR (Code: 33557097)~~ - -~~ERROR (Message: trigger "babel_2170_vu_employees_view_iot_update" already exists in the database)~~ - - --- Same trigger name on a Table in same schema -CREATE TRIGGER babel_2170_vu_employees_view_iot_update ON babel_2170_vu_employees -INSTEAD OF INSERT -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees__table_iot_update Invoked' -END -GO -~~ERROR (Code: 33557097)~~ - -~~ERROR (Message: trigger "babel_2170_vu_employees_view_iot_update" already exists in the database)~~ - - - --- Test Instead of Update trigger in same db but cross schema --- Cleanup default dbo schema IO Update trigger -DROP TRIGGER IF EXISTS [dbo].[babel_2170_vu_employees_view_iot_update]; -GO - -CREATE TRIGGER [schema_2170].[babel_2170_vu_employees_view_iot_update] ON [schema_2170].[babel_2170_vu_employees_view] -INSTEAD OF UPDATE -AS - SELECT 'Trigger db1_BABEL2170.schema_2170.babel_2170_vu_employees_view_iot_update Invoked' -GO - -CREATE TRIGGER [babel_2170_vu_employees_view_iot_update] ON [babel_2170_vu_employees_view] -INSTEAD OF UPDATE -AS - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_update Invoked' -GO - -UPDATE [schema_2170].[babel_2170_vu_employees_view] SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO -~~START~~ -varchar -Trigger db1_BABEL2170.schema_2170.babel_2170_vu_employees_view_iot_update Invoked -~~END~~ - -~~ROW COUNT: 1~~ - - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM [schema_2170].[babel_2170_vu_employees_view] ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2000.00 -~~END~~ - - -UPDATE [dbo].[babel_2170_vu_employees_view] SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO -~~START~~ -varchar -Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_update Invoked -~~END~~ - -~~ROW COUNT: 1~~ - - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM [dbo].[babel_2170_vu_employees_view] ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2000.00 -~~END~~ - - --- drop dbo schema trigger and test that schema_2170.update trigger is not dropped -DROP TRIGGER IF EXISTS [dbo].[babel_2170_vu_employees_view_iot_update]; -GO - -UPDATE [schema_2170].[babel_2170_vu_employees_view] SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO -~~START~~ -varchar -Trigger db1_BABEL2170.schema_2170.babel_2170_vu_employees_view_iot_update Invoked -~~END~~ - -~~ROW COUNT: 1~~ - - --- schema_2170 object cleanup -DROP TRIGGER IF EXISTS [schema_2170].babel_2170_vu_employees_view_iot_update; -GO - -DROP VIEW IF EXISTS [schema_2170].babel_2170_vu_employees_view; -GO - -DROP TABLE IF EXISTS [schema_2170].babel_2170_vu_employees; -GO - -DROP SCHEMA IF EXISTS schema_2170; -GO - --- Test Transaction Commit and Rollback inside Instead of triggers -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_update ON babel_2170_vu_employees_view_txn -INSTEAD OF UPDATE -AS - BEGIN - BEGIN TRAN; - INSERT INTO babel_2170_vu_employees_view_txn VALUES(3, 'adam', '1st Street', '3000'); - COMMIT tran; - END -GO - -UPDATE babel_2170_vu_employees_view_txn SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO -~~ROW COUNT: 1~~ - -~~ROW COUNT: 1~~ - - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2000.00 -3#!#adam#!#1st Street#!#3000.00 -~~END~~ - - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_update; -GO - -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_update ON babel_2170_vu_employees_view_txn -INSTEAD OF UPDATE -AS - BEGIN - BEGIN TRAN; - INSERT INTO babel_2170_vu_employees_view_txn VALUES(3, 'adam', '1st Street', '3000'); - ROLLBACK tran; - END -GO - -UPDATE babel_2170_vu_employees_view_txn SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO -~~ROW COUNT: 1~~ - -~~ERROR (Code: 3609)~~ - -~~ERROR (Message: The transaction ended in the trigger. The batch has been aborted.)~~ - - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2000.00 -3#!#adam#!#1st Street#!#3000.00 -~~END~~ - - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_update; -GO - -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_insert ON babel_2170_vu_employees_view_txn INSTEAD OF INSERT AS -BEGIN TRAN; -UPDATE babel_2170_vu_employees_view_txn SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -COMMIT; -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -SELECT * FROM inserted; -GO - -BEGIN TRAN; -GO -INSERT INTO babel_2170_vu_employees_view_txn VALUES(4, 'ana', '1st Street', '4000'); -GO -~~ROW COUNT: 1~~ - -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2001.00 -3#!#adam#!#1st Street#!#3000.00 -~~END~~ - -~~START~~ -int#!#varchar#!#varchar#!#numeric -4#!#ana#!#1st Street#!#4000.00 -~~END~~ - -~~ROW COUNT: 1~~ - -COMMIT; -GO - -BEGIN TRAN -GO -INSERT INTO babel_2170_vu_employees_view_txn VALUES(4, 'ana', '1st Street', '4000'); -GO -~~ROW COUNT: 1~~ - -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2002.00 -3#!#adam#!#1st Street#!#3000.00 -~~END~~ - -~~START~~ -int#!#varchar#!#varchar#!#numeric -4#!#ana#!#1st Street#!#4000.00 -~~END~~ - -~~ROW COUNT: 1~~ - -IF (@@trancount > 0) ROLLBACK; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2001.00 -3#!#adam#!#1st Street#!#3000.00 -~~END~~ - - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_insert; -GO - -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_update ON babel_2170_vu_employees_view_txn INSTEAD OF UPDATE AS -SAVE TRAN sp1; -SAVE TRAN sp2; -DELETE FROM babel_2170_vu_employees_view_txn where EmployeeID =2; -ROLLBACK TRAN sp1; -GO - -BEGIN TRAN -GO -SELECT @@trancount; -UPDATE babel_2170_vu_employees_view_txn SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO -~~START~~ -int -1 -~~END~~ - -~~ROW COUNT: 1~~ - -~~ROW COUNT: 1~~ - -IF (@@trancount > 0) ROLLBACK; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2001.00 -3#!#adam#!#1st Street#!#3000.00 -~~END~~ - - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_update; -GO - -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_delete ON babel_2170_vu_employees_view_txn INSTEAD OF DELETE AS -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -INSERT INTO babel_2170_vu_employees_view_txn VALUES(5, 'ash', '1st Street', '5000'); -SELECT * FROM deleted; -GO - -DELETE FROM babel_2170_vu_employees_view_txn where EmployeeID =1; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2001.00 -3#!#adam#!#1st Street#!#3000.00 -~~END~~ - -~~ROW COUNT: 1~~ - -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -~~END~~ - -~~ROW COUNT: 1~~ - - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2001.00 -3#!#adam#!#1st Street#!#3000.00 -5#!#ash#!#1st Street#!#5000.00 -~~END~~ - - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_delete; -GO - --- test multi-db mode -SELECT set_config('role', 'jdbc_user', false); -GO -~~START~~ -text -jdbc_user -~~END~~ - - -SELECT set_config('babelfishpg_tsql.migration_mode', 'multi-db', false); -GO -~~START~~ -text -multi-db -~~END~~ - - -CREATE DATABASE db2_BABEL2170; -GO - -USE db2_BABEL2170; -GO - -CREATE TABLE babel_2170_vu_employees -( - EmployeeID int NOT NULL, - EmployeeName VARCHAR(50), - EmployeeAddress VARCHAR(50), - MonthSalary NUMERIC(10, 2) -) -GO - -INSERT INTO babel_2170_vu_employees VALUES(1, 'amber', '1st Street', '1000'); -INSERT INTO babel_2170_vu_employees VALUES(2, 'angel', '1st Street', '2000'); -GO -~~ROW COUNT: 1~~ - -~~ROW COUNT: 1~~ - - -CREATE VIEW babel_2170_vu_employees_view AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees -WHERE EmployeeName LIKE 'a%'; -GO - --- create same name Instead of Insert trigger in second db to test Cross db behavior -CREATE TRIGGER babel_2170_vu_employees_view_iot_insert ON babel_2170_vu_employees_view -INSTEAD OF INSERT -AS -BEGIN - SELECT 'Trigger db2_BABEL2170.dbo.babel_2170_vu_employees_view_iot_insert Invoked' -END -GO - --- should fire IOT trigger of second db -INSERT INTO babel_2170_vu_employees_view VALUES(3, 'adam', '1st Street db2_BABEL2170', '3000'); -GO -~~START~~ -varchar -Trigger db2_BABEL2170.dbo.babel_2170_vu_employees_view_iot_insert Invoked -~~END~~ - -~~ROW COUNT: 1~~ - - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view ORDER BY EmployeeID; -GO -~~START~~ -int#!#varchar#!#varchar#!#numeric -1#!#amber#!#1st Street#!#1000.00 -2#!#angel#!#1st Street#!#2000.00 -~~END~~ - - --- clean all objects in second database -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_insert; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view; -GO - -DROP TABLE IF EXISTS babel_2170_vu_employees; -GO - -USE MASTER; -GO - -DROP DATABASE IF EXISTS db2_BABEL2170; -GO diff --git a/test/JDBC/input/triggers/BABEL-2170-vu-cleanup.sql b/test/JDBC/input/triggers/BABEL-2170-vu-cleanup.sql deleted file mode 100644 index 0f656cfde4..0000000000 --- a/test/JDBC/input/triggers/BABEL-2170-vu-cleanup.sql +++ /dev/null @@ -1,39 +0,0 @@ --- clean all objects in first database -USE db1_BABEL2170; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_insert; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_update; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_delete; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_bulkinsert; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view_bulkinsert; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view_2; -GO - -DROP TABLE IF EXISTS babel_2170_vu_employees; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view_txn; -GO - -DROP TABLE IF EXISTS babel_2170_vu_employees_txn; -GO - -USE MASTER; -GO - -DROP DATABASE IF EXISTS db1_BABEL2170; -GO \ No newline at end of file diff --git a/test/JDBC/input/triggers/BABEL-2170-vu-prepare.sql b/test/JDBC/input/triggers/BABEL-2170-vu-prepare.sql deleted file mode 100644 index cb31bf570b..0000000000 --- a/test/JDBC/input/triggers/BABEL-2170-vu-prepare.sql +++ /dev/null @@ -1,93 +0,0 @@ --- We will create two databases db1_BABEL2170, db2_BABEL2170 -CREATE DATABASE db1_BABEL2170; -GO - -USE db1_BABEL2170; -GO - -CREATE TABLE babel_2170_vu_employees -( - EmployeeID int NOT NULL, - EmployeeName VARCHAR(50), - EmployeeAddress VARCHAR(50), - MonthSalary NUMERIC(10, 2) -) -GO - -INSERT INTO babel_2170_vu_employees VALUES(1, 'amber', '1st Street', '1000'); -INSERT INTO babel_2170_vu_employees VALUES(2, 'angel', '1st Street', '2000'); -GO - -CREATE VIEW babel_2170_vu_employees_view AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees -WHERE EmployeeName LIKE 'a%'; -GO - -CREATE VIEW babel_2170_vu_employees_view_bulkinsert AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees -WHERE EmployeeName LIKE 'b%'; -GO - -CREATE VIEW babel_2170_vu_employees_view_2 AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees -WHERE EmployeeName LIKE 'a%'; -GO - -CREATE SCHEMA schema_2170; -GO - -CREATE TABLE schema_2170.babel_2170_vu_employees -( - EmployeeID int NOT NULL, - EmployeeName VARCHAR(50), - EmployeeAddress VARCHAR(50), - MonthSalary NUMERIC(10, 2) -) -GO - -INSERT INTO schema_2170.babel_2170_vu_employees VALUES(1, 'amber', '1st Street', '1000'); -INSERT INTO schema_2170.babel_2170_vu_employees VALUES(2, 'angel', '1st Street', '2000'); -GO - -CREATE VIEW schema_2170.babel_2170_vu_employees_view AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM schema_2170.babel_2170_vu_employees -WHERE EmployeeName LIKE 'a%'; -GO - -CREATE TABLE babel_2170_vu_employees_txn -( - EmployeeID int NOT NULL, - EmployeeName VARCHAR(50), - EmployeeAddress VARCHAR(50), - MonthSalary NUMERIC(10, 2) -) -GO - -INSERT INTO babel_2170_vu_employees_txn VALUES(1, 'amber', '1st Street', '1000'); -INSERT INTO babel_2170_vu_employees_txn VALUES(2, 'angel', '1st Street', '2000'); -GO - -CREATE VIEW babel_2170_vu_employees_view_txn AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees_txn -WHERE EmployeeName LIKE 'a%'; -GO \ No newline at end of file diff --git a/test/JDBC/input/triggers/BABEL-2170-vu-verify.sql b/test/JDBC/input/triggers/BABEL-2170-vu-verify.sql deleted file mode 100644 index c7802b6db5..0000000000 --- a/test/JDBC/input/triggers/BABEL-2170-vu-verify.sql +++ /dev/null @@ -1,321 +0,0 @@ -USE db1_BABEL2170; -GO - --- Instead of Insert Trigger on View -CREATE TRIGGER babel_2170_vu_employees_view_iot_insert ON babel_2170_vu_employees_view -INSTEAD OF INSERT -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_insert Invoked' -END -GO - -INSERT INTO babel_2170_vu_employees_view VALUES(3, 'adam', '1st Street', '3000'); -GO - -SELECT COUNT(EmployeeID) FROM babel_2170_vu_employees; -GO - -SELECT COUNT(EmployeeID) FROM babel_2170_vu_employees_view; -GO - --- Instead of Update Trigger on View -CREATE TRIGGER babel_2170_vu_employees_view_iot_update ON babel_2170_vu_employees_view -INSTEAD OF UPDATE -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_update Invoked' -END -GO - -UPDATE babel_2170_vu_employees_view SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO - -SELECT EmployeeID,EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees WHERE EmployeeID = 2 ORDER BY EmployeeID; -GO - -BEGIN TRANSACTION - UPDATE babel_2170_vu_employees_view SET MonthSalary = MonthSalary +1 WHERE EmployeeID IN (1, 2); -COMMIT TRANSACTION; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees WHERE EmployeeID IN (1, 2) ORDER BY EmployeeID; -GO - --- Instead of Delete Trigger on View -CREATE TRIGGER babel_2170_vu_employees_view_iot_delete ON babel_2170_vu_employees_view -INSTEAD OF DELETE -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_delete Invoked' -END -GO - -BEGIN TRANSACTION - DELETE FROM babel_2170_vu_employees_view WHERE EmployeeID IN (1, 2); -COMMIT TRANSACTION; -GO - -SELECT COUNT(EmployeeID) FROM babel_2170_vu_employees_view; -GO - -SELECT COUNT(EmployeeID) FROM babel_2170_vu_employees; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view ORDER BY EmployeeID; -GO - ---- Tests multiple insert queries and check if inserted table can be accessed and trigger is working fine. -CREATE TRIGGER babel_2170_vu_employees_view_iot_bulkinsert ON babel_2170_vu_employees_view_bulkinsert -INSTEAD OF INSERT -AS - SELECT * FROM INSERTED; -GO - -BEGIN TRANSACTION -DECLARE @i int = 1 - WHILE @i <= 3 - BEGIN - INSERT INTO babel_2170_vu_employees_view_bulkinsert VALUES(@i, 'bob', '1st Street', '1000'); - SET @i = @i + 1 - END -COMMIT TRANSACTION -GO - --- Same trigger name on different View created on Same table in same schema -CREATE TRIGGER babel_2170_vu_employees_view_iot_update ON babel_2170_vu_employees_view_2 -INSTEAD OF INSERT -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view2_iot_update Invoked' -END -GO - --- Same trigger name on a Table in same schema -CREATE TRIGGER babel_2170_vu_employees_view_iot_update ON babel_2170_vu_employees -INSTEAD OF INSERT -AS -BEGIN - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees__table_iot_update Invoked' -END -GO - --- Test Instead of Update trigger in same db but cross schema - --- Cleanup default dbo schema IO Update trigger -DROP TRIGGER IF EXISTS [dbo].[babel_2170_vu_employees_view_iot_update]; -GO - -CREATE TRIGGER [schema_2170].[babel_2170_vu_employees_view_iot_update] ON [schema_2170].[babel_2170_vu_employees_view] -INSTEAD OF UPDATE -AS - SELECT 'Trigger db1_BABEL2170.schema_2170.babel_2170_vu_employees_view_iot_update Invoked' -GO - -CREATE TRIGGER [babel_2170_vu_employees_view_iot_update] ON [babel_2170_vu_employees_view] -INSTEAD OF UPDATE -AS - SELECT 'Trigger db1_BABEL2170.dbo.babel_2170_vu_employees_view_iot_update Invoked' -GO - -UPDATE [schema_2170].[babel_2170_vu_employees_view] SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM [schema_2170].[babel_2170_vu_employees_view] ORDER BY EmployeeID; -GO - -UPDATE [dbo].[babel_2170_vu_employees_view] SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM [dbo].[babel_2170_vu_employees_view] ORDER BY EmployeeID; -GO - --- drop dbo schema trigger and test that schema_2170.update trigger is not dropped -DROP TRIGGER IF EXISTS [dbo].[babel_2170_vu_employees_view_iot_update]; -GO - -UPDATE [schema_2170].[babel_2170_vu_employees_view] SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO - --- schema_2170 object cleanup -DROP TRIGGER IF EXISTS [schema_2170].babel_2170_vu_employees_view_iot_update; -GO - -DROP VIEW IF EXISTS [schema_2170].babel_2170_vu_employees_view; -GO - -DROP TABLE IF EXISTS [schema_2170].babel_2170_vu_employees; -GO - -DROP SCHEMA IF EXISTS schema_2170; -GO - --- Test Transaction Commit and Rollback inside Instead of triggers -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_update ON babel_2170_vu_employees_view_txn -INSTEAD OF UPDATE -AS - BEGIN - BEGIN TRAN; - INSERT INTO babel_2170_vu_employees_view_txn VALUES(3, 'adam', '1st Street', '3000'); - COMMIT tran; - END -GO - -UPDATE babel_2170_vu_employees_view_txn SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_update; -GO - -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_update ON babel_2170_vu_employees_view_txn -INSTEAD OF UPDATE -AS - BEGIN - BEGIN TRAN; - INSERT INTO babel_2170_vu_employees_view_txn VALUES(3, 'adam', '1st Street', '3000'); - ROLLBACK tran; - END -GO - -UPDATE babel_2170_vu_employees_view_txn SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_update; -GO - -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_insert ON babel_2170_vu_employees_view_txn INSTEAD OF INSERT AS -BEGIN TRAN; -UPDATE babel_2170_vu_employees_view_txn SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -COMMIT; -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -SELECT * FROM inserted; -GO - -BEGIN TRAN; -GO -INSERT INTO babel_2170_vu_employees_view_txn VALUES(4, 'ana', '1st Street', '4000'); -GO -COMMIT; -GO - -BEGIN TRAN -GO -INSERT INTO babel_2170_vu_employees_view_txn VALUES(4, 'ana', '1st Street', '4000'); -GO -IF (@@trancount > 0) ROLLBACK; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_insert; -GO - -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_update ON babel_2170_vu_employees_view_txn INSTEAD OF UPDATE AS -SAVE TRAN sp1; -SAVE TRAN sp2; -DELETE FROM babel_2170_vu_employees_view_txn where EmployeeID =2; -ROLLBACK TRAN sp1; -GO - -BEGIN TRAN -GO -SELECT @@trancount; -UPDATE babel_2170_vu_employees_view_txn SET MonthSalary = MonthSalary +1 WHERE EmployeeID = 2; -GO -IF (@@trancount > 0) ROLLBACK; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_update; -GO - -CREATE TRIGGER babel_2170_vu_employees_view_iot_txn_delete ON babel_2170_vu_employees_view_txn INSTEAD OF DELETE AS -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -INSERT INTO babel_2170_vu_employees_view_txn VALUES(5, 'ash', '1st Street', '5000'); -SELECT * FROM deleted; -GO - -DELETE FROM babel_2170_vu_employees_view_txn where EmployeeID =1; -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view_txn ORDER BY EmployeeID; -GO - -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_txn_delete; -GO - --- test multi-db mode -SELECT set_config('role', 'jdbc_user', false); -GO - -SELECT set_config('babelfishpg_tsql.migration_mode', 'multi-db', false); -GO - -CREATE DATABASE db2_BABEL2170; -GO - -USE db2_BABEL2170; -GO - -CREATE TABLE babel_2170_vu_employees -( - EmployeeID int NOT NULL, - EmployeeName VARCHAR(50), - EmployeeAddress VARCHAR(50), - MonthSalary NUMERIC(10, 2) -) -GO - -INSERT INTO babel_2170_vu_employees VALUES(1, 'amber', '1st Street', '1000'); -INSERT INTO babel_2170_vu_employees VALUES(2, 'angel', '1st Street', '2000'); -GO - -CREATE VIEW babel_2170_vu_employees_view AS -SELECT EmployeeID, - EmployeeName, - EmployeeAddress, - MonthSalary -FROM babel_2170_vu_employees -WHERE EmployeeName LIKE 'a%'; -GO - --- create same name Instead of Insert trigger in second db to test Cross db behavior -CREATE TRIGGER babel_2170_vu_employees_view_iot_insert ON babel_2170_vu_employees_view -INSTEAD OF INSERT -AS -BEGIN - SELECT 'Trigger db2_BABEL2170.dbo.babel_2170_vu_employees_view_iot_insert Invoked' -END -GO - --- should fire IOT trigger of second db -INSERT INTO babel_2170_vu_employees_view VALUES(3, 'adam', '1st Street db2_BABEL2170', '3000'); -GO - -SELECT EmployeeID, EmployeeName, EmployeeAddress, MonthSalary FROM babel_2170_vu_employees_view ORDER BY EmployeeID; -GO - --- clean all objects in second database -DROP TRIGGER IF EXISTS babel_2170_vu_employees_view_iot_insert; -GO - -DROP VIEW IF EXISTS babel_2170_vu_employees_view; -GO - -DROP TABLE IF EXISTS babel_2170_vu_employees; -GO - -USE MASTER; -GO - -DROP DATABASE IF EXISTS db2_BABEL2170; -GO \ No newline at end of file diff --git a/test/JDBC/upgrade/latest/schedule b/test/JDBC/upgrade/latest/schedule index 9743239b1d..6910c4bdeb 100644 --- a/test/JDBC/upgrade/latest/schedule +++ b/test/JDBC/upgrade/latest/schedule @@ -38,7 +38,6 @@ BABEL-1963 BABEL-1994-CHAR BABEL-1994-VARCHAR BABEL-2086 -BABEL-2170 BABEL-2203 BABEL-2208 BABEL-2257