To Refresh workspace
begin
dbms_wm.gotoworkspace('B_focus_9');
dbms_wm.refreshworkspace('B_focus_9');
end;
But if there are conflicts refreshworkspace will result an error
ORA-20056: conflicts detected for workspace: 'B_focus_9' in table: 'USER.TEST'
LIVE WORKSPACE CANNOT BE REFRESHED
The two rows that changed in both the LIVE and the 'B_focus_9' workspace create a conflict. These conflicts can be seen from the view Test_conf. But first go to the 'B_focus_9' workspace. The conflicts are not visible in this view while being in the LIVE workspace.
--------------------------
To Resolve this conflicts
SELECT * FROM test_conf ORDER BY wm_workspace;
begin
dbms_wm.gotoworkspace('B_focus_9');
dbms_wm.beginresolve('B_focus_9');
dbms_wm.resolveconflicts('B_focus_9','TEST',null/*where clause*/,'PARENT');
commit;
end;
begin
dbms_wm.commitresolve('B_focus_9');
end;
SELECT * FROM test_conf ORDER BY wm_workspace;
After resolving this conflict the workspace can be refreshed
begin
dbms_wm.refreshworkspace('B_focus_9');
end;
Merge Workspace
begin
dbms_wm.mergeworkspace('B_focus_9');
end;
When B_focus_9 workspace is merged into the LIVE workspace. A merge is the opposite of a refresh : it updates the parent workspace (LIVE) with the changes made to the merged workspace (B_focus_9). Where as refresh operation updates the refreshing workspace.
---------------------------------
After MergeWorkspace See Difference
begin
dbms_wm.gotoworkspace('B_focus_1');
end;
select * from test order by one
begin
dbms_wm.gotoworkspace('B_focus_9');
end;
select * from test order by one
begin
dbms_wm.gotoworkspace('LIVE');
end;
select * from test order by one
Here parent workspace (LIVE) was updated by merged workspace (B_focus_9) .
----------------
Mar 26, 2009
Oracle Workspace 2
The merge operation does not currently work with versioned tables. The optimizer translates the merge into
insert/update statements on the underlying _LT table
To have several versions of data
create table TEST (
one number primary key, -- Without primary key: ORA-20133:
two varchar2(15), three char(2), four clob,
five blob, six date );
insert into test values (1,'Cochin','NO','Kochi is a vibrant city situated on the south-west coast of the Indian peninsula in the breathtakingly scenic and prosperous state of Kerala, hailed as Gods Own Country',null,sysdate);
insert into test values (2,'Kerala','YS','n',null,sysdate);
insert into test values (3,'TVM','NO','n',null,sysdate);
insert into test values (4,'Calicut','NO','n',null,sysdate);
insert into test values (5,'Kannur','YS','n',null,sysdate);
commit;
begin
dbms_wm.enableversioning ('test');
end;
begin
dbms_wm.createworkspace ('B_focus_1');
dbms_wm.createworkspace ('B_focus_9' );
end;
begin
dbms_wm.gotoworkspace('B_focus_1');
dbms_wm.createworkspace ('test' );
end;
select workspace, parent_workspace from user_workspaces;
select * from test order by one;
update test set two='Kasargode',three='NO',four='Top end of Kerala',Six=sysdate where one=2;
commit;
begin
dbms_wm.gotoworkspace('LIVE');
end;
select * from test order by one
begin
dbms_wm.gotoworkspace('B_focus_9');
end;
select * from test order by one
update test set two='Thrissur',three='NO',four='Middle of Kerala',Six=sysdate where one=2;
commit;
select * from test order by one
begin
dbms_wm.gotoworkspace('test');
end;
select * from test order by one
insert/update statements on the underlying _LT table
To have several versions of data
create table TEST (
one number primary key, -- Without primary key: ORA-20133:
two varchar2(15), three char(2), four clob,
five blob, six date );
insert into test values (1,'Cochin','NO','Kochi is a vibrant city situated on the south-west coast of the Indian peninsula in the breathtakingly scenic and prosperous state of Kerala, hailed as Gods Own Country',null,sysdate);
insert into test values (2,'Kerala','YS','n',null,sysdate);
insert into test values (3,'TVM','NO','n',null,sysdate);
insert into test values (4,'Calicut','NO','n',null,sysdate);
insert into test values (5,'Kannur','YS','n',null,sysdate);
commit;
begin
dbms_wm.enableversioning ('test');
end;
begin
dbms_wm.createworkspace ('B_focus_1');
dbms_wm.createworkspace ('B_focus_9' );
end;
begin
dbms_wm.gotoworkspace('B_focus_1');
dbms_wm.createworkspace ('test' );
end;
select workspace, parent_workspace from user_workspaces;
select * from test order by one;
update test set two='Kasargode',three='NO',four='Top end of Kerala',Six=sysdate where one=2;
commit;
begin
dbms_wm.gotoworkspace('LIVE');
end;
select * from test order by one
begin
dbms_wm.gotoworkspace('B_focus_9');
end;
select * from test order by one
update test set two='Thrissur',three='NO',four='Middle of Kerala',Six=sysdate where one=2;
commit;
select * from test order by one
begin
dbms_wm.gotoworkspace('test');
end;
select * from test order by one
Mar 25, 2009
Oracle Workspace 1
Workspace Manager PL/SQL APIs
The PL/SQL APIs in the DBMS_WM package can be executed
* Workspace operations: create,refresh,merge,rollback remove,goto,compress,alter
* Savepoints: create, alter, goto
* History: goto date
* Privileges: access, create, delete, rollback and merge workspace
* Access Modes: read, write, management or no access to workspaces
* Locks: exclusive and shared workspace locks to prevent data update conflicts
* Find Differences: compare savepoints and workspaces
* Detect / Resolve Conflicts: Automatically detect and resolve conflicts
When a particular table is versioned primary key index is rebuild version field is added with the current primary key fields inorder to uniquely identify each row version .Each table that is versioned with the workspace manager must have a primary key.No issue if there is a Foreign Key
To get Lock Mode
SELECT dbms_wm.GetLockMode FROM dual;
Some Errors
-----------
(I)ORA-20101: child table must be version enabled (This error occur if TEST table is referenced by another table TESTCHILD ;if TESTCHILD is version enabled then only TEST table can be versioned )
(II)ORA-20100: 'USER.TEST' is both parent and child tables of referential integrity constraints
If a field of TEST table is referenced by another field of TEST table itself such tables cannot be version-
enabled ie:( In Scott.EMP table MGR field is referenced by EMPNO field )
ALTER TABLE EMP ADD CONSTRAINT FK_EMP
FOREIGN KEY (MGR) REFERENCES EMP (EMPNO) )
(III) Temporary Table cannot be version enabled
ORA-20229:statement 'CREATE INDEX TMP_TEST_PKI$ on TMP_TEST_LT(A)LOGGING PCTFREE 10 INITRANS 2 M' failed during EnableVersioning.Error:
ORA-14451: unsupported feature with temporary table
Referential integrity constraints cannot be added after versioning is enabled. They must be present before version-enabling
------------------*------------------*---------------------*----------------
EXEC DBMS_WM.FINDRICSET('B_focus_1', 'RICTEST') ; --CREATE A TABLE WITH FIELD TABLE_OWNER & TABLE_NAME WITH DATA
SELECT dbms_wm.GetPrivs('LIVE') FROM dual ; //GET Privileges of particular workspace
To Get Lock Mode
SELECT dbms_wm.GetLockMode FROM dual ;
DECLARE
lockmode varchar2(1);
begin
lockMode := sys.lt_ctx_pkg.lock_Mode;
dbms_output.put_line(lockMode);
end;
The min & max time that Oracle supports
SELECT DBMS_WM.max_time,DBMS_WM.min_time FROM DUAL; (from 10g onwards)
The PL/SQL APIs in the DBMS_WM package can be executed
* Workspace operations: create,refresh,merge,rollback remove,goto,compress,alter
* Savepoints: create, alter, goto
* History: goto date
* Privileges: access, create, delete, rollback and merge workspace
* Access Modes: read, write, management or no access to workspaces
* Locks: exclusive and shared workspace locks to prevent data update conflicts
* Find Differences: compare savepoints and workspaces
* Detect / Resolve Conflicts: Automatically detect and resolve conflicts
When a particular table is versioned primary key index is rebuild version field is added with the current primary key fields inorder to uniquely identify each row version .Each table that is versioned with the workspace manager must have a primary key.No issue if there is a Foreign Key
To get Lock Mode
SELECT dbms_wm.GetLockMode FROM dual;
Some Errors
-----------
(I)ORA-20101: child table must be version enabled (This error occur if TEST table is referenced by another table TESTCHILD ;if TESTCHILD is version enabled then only TEST table can be versioned )
(II)ORA-20100: 'USER.TEST' is both parent and child tables of referential integrity constraints
If a field of TEST table is referenced by another field of TEST table itself such tables cannot be version-
enabled ie:( In Scott.EMP table MGR field is referenced by EMPNO field )
ALTER TABLE EMP ADD CONSTRAINT FK_EMP
FOREIGN KEY (MGR) REFERENCES EMP (EMPNO) )
(III) Temporary Table cannot be version enabled
ORA-20229:statement 'CREATE INDEX TMP_TEST_PKI$ on TMP_TEST_LT(A)LOGGING PCTFREE 10 INITRANS 2 M' failed during EnableVersioning.Error:
ORA-14451: unsupported feature with temporary table
Referential integrity constraints cannot be added after versioning is enabled. They must be present before version-enabling
------------------*------------------*---------------------*----------------
EXEC DBMS_WM.FINDRICSET('B_focus_1', 'RICTEST') ; --CREATE A TABLE WITH FIELD TABLE_OWNER & TABLE_NAME WITH DATA
SELECT dbms_wm.GetPrivs('LIVE') FROM dual ; //GET Privileges of particular workspace
To Get Lock Mode
SELECT dbms_wm.GetLockMode FROM dual ;
DECLARE
lockmode varchar2(1);
begin
lockMode := sys.lt_ctx_pkg.lock_Mode;
dbms_output.put_line(lockMode);
end;
The min & max time that Oracle supports
SELECT DBMS_WM.max_time,DBMS_WM.min_time FROM DUAL; (from 10g onwards)
Mar 19, 2009
Oracle Workspace
With Oracle's Workspace Manager it's possible to have several versions of data. That is, data can be changed, thus making a new version, without affecting application data.For this a new workspace is to be created and the table is to be versioned
Workspace allows multiple transactions to exist within one table in a schema. This allows several departments or functional areas to work against a single schema without interfering with data from other groups. Changes to version-enabled tables are captured as new rows within the workspace. These changes are invisible to other workspaces until they are merged into a parent workspace.
The functionality (Packages, Procedures, Functions) used for the Workspace Manager are found in the wmsys schema.
In a workspace hierarchy consisting of Live->PreProduction->Development workspaces, the Development workspace can see all row changes made in the PreProduction workspace, along with all committed data from non-version-enabled tables belonging to the Live workspace. In addition it can see data from version-enabled tables in Live as they were when the PreProduction workspace was created. Once a workspace is refreshed, all changes can be cascaded down the hierarchy.
Workspace Manager makes only a copy of row it is changed ,which reduce hardware , software and time needed to manage multiple version of data in different schemas .A workspace is a virtual environment not physical storage.The default workspace is called LIVE.
Main concepts used for workspace are Instead of Triggers and Context .
For More On WorkSpace
To get Version
SELECT dbms_wm.getversion FROM dual;
To create Workspace
begin
dbms_wm.createworkspace('B_focus_1');
end;
select workspace, parent_workspace from user_workspaces;
To move to workspace
begin
dbms_wm.gotoworkspace('B_focus_1');
end;
To enable versoning for a table
begin
dbms_wm.enableversioning (table_name,hist);
end;
1)The length of a table name must not exceed 25 characters. The name is not case sensitive
2) Hist
NONE: No modifications to the table are tracked. (This is the default.)
VIEW_W_OVERWRITE: The with overwrite (W_OVERWRITE) option: A view named_HIST is created to contain history information, but it will show only the most recent modifications to the same version of the table. A history of modifications to the version is not maintained; that is, subsequent changes to a row in the same version overwrite earlier changes. (The CREATETIME column of the _HIST view contains only the time of the most recent update.)
VIEW_WO_OVERWRITE: The without overwrite (WO_OVERWRITE) option: A view named_HIST is created to contain history information, and it will show all modifications to the same version of the table. A history of modifications to the version is maintained; that is, subsequent changes to a row in the same version do not overwrite earlier changes.
If the table is version-enabled with the VIEW_WO_OVERWRITE hist option specified, this option can later be disabled and re-enabled by calling the SetWoOverwriteOFF Procedure and SetWoOverwriteON Procedure.
begin
DBMS_WM.SetWoOverwriteOFF();
end;
This procedure enables the VIEW_WO_OVERWRITE history option that had been disabled by the SetWoOverwriteOFF Procedure.
begin
DBMS_WM.SetWoOverwriteON();
end;
---------------------------------------
a)Only the owner of a table can enable versioning on the table.
b)Tables that are version-enabled and users that own version-enabled tables cannot be deleted. You must first disable versioning on the relevant table or tables.
c)Tables owned by SYS cannot be version-enabled.
d)DDL operations are not allowed on version-enabled tables.
e)Index-organized tables cannot be version-enabled.
f)Object tables cannot be version-enabled.
g)A table with one or more columns of LONG data type cannot be version-enabled.
------------------------------------------------------------
Example
begin
dbms_wm.enableversioning ('TEST');
end;
This will rename the TEST table to TEST_LT(LT stands for Long Transaction ie:Completes over days or week ) and create a view called TEST (which contains original data for more detail refer script of view) addition to this 9 other views will be created.The view uses instead-of triggers to perform all operations against the version enabled table. This hides a lot of the versioning mechanism from the users.
The TEST_LT table has the following additional columns:
VERSION NOT NULL NUMBER(38)
NEXTVER VARCHAR2(500)
DELSTATUS NUMBER(38)
LTLOCK VARCHAR2(100)
Values for following tables when table is version enabled (0,-1,10,!O!)
Test_MV (Materialized view) View it contains data ;which the field is not affected ;with two extra fields WM_MODIFIEDBY and WM_OPTYPE
Test_base view contains the field of original table in addition RID,version,nextver,delstatus,ltlock
Test_BPKC contains fields Rowids of child,parent and base ,childstate ,parentstate ,DS and VER of child,parent & base (ie : 12 fields) if we are in LIVE workspace there will not be an data in it because it is in parent state if it is in any of child workspace there will be data
Test_PKC contains all the fields of Text_BPKC excluding Firstchildver
TEST_HIST This view is created only if ; during table versioning (ie: enableversioning) if we supply hist parameter if hist parameter is NONE then this view will not be there to track history details .
IF active workspace is LIVE then TEST,TEST_BASE,TEST_MV view only have records
Test_conf (Conflict) view contains all fields in Test addition to those wm_workspace,wm_delted
To disable versoning
begin
dbms_wm.disableversioning ('TEST');
end;
To compress WorkSpace
begin
dbms_wm.compressworkspace('LIVE');
end;
To view curent workspace
SELECT DBMS_WM.getworkspace FROM DUAL;
SELECT DBMS_WM.isworkspaceoccupied('B_focus_1') FROM DUAL;
To view versionenabled tables
select * from wmsys.wm$table_parvers_view
SELECT * FROM user_wm_versioned_tables;
To get current version number
select * from wmsys.WM$CURRENT_VER_VIEW;
To get current and next version
select * from wmsys.WM$CURRENT_NEXTVERS_VIEW;
To get current hierarchy of workspace
select * from wmsys.WM$CURRENT_HIERARCHY_VIEW;
select * from wmsys.WM$CONF1_HIERARCHY_VIEW;
To get parent of a workspace
You should be in a workspace other than LIVE then only we get data from this view ; because for LIVE workspace is parent of .
select * from wmsys.WM$PARENT_HIERARCHY_VIEW;
To get constraints of version enabled tables
select * from wmsys.USER_WM_CONSTRAINTS;
To get indexes of version enabled tables
select * from wmsys.USER_WM_IND_COLUMNS;
To get details of versionenabled tables that are modified
select * from wmsys.USER_WM_MODIFIED_TABLES;
To get trigger details on version enabled tables
select * from wmsys.USER_WM_TAB_TRIGGERS;
To get details of locked tables
select * from wmsys.USER_WM_LOCKED_TABLES;
To get details of version enabled tables
select * from wmsys.USER_WM_VERSIONED_TABLES;
To get errors in workspace
select * from wmsys.USER_WM_VT_ERRORS;
To get savepointdetails
select * from wmsys.USER_WORKSPACE_SAVEPOINTS;
To get foreign key of version enabled tables
select * from wmsys.USER_WM_RIC_INFO;
To get current hierarchy and depth of workspace
select * from wmsys.ALL_VERSION_HVIEW_WDEPTH;
--------------------------------------------------------
Workspace allows multiple transactions to exist within one table in a schema. This allows several departments or functional areas to work against a single schema without interfering with data from other groups. Changes to version-enabled tables are captured as new rows within the workspace. These changes are invisible to other workspaces until they are merged into a parent workspace.
The functionality (Packages, Procedures, Functions) used for the Workspace Manager are found in the wmsys schema.
In a workspace hierarchy consisting of Live->PreProduction->Development workspaces, the Development workspace can see all row changes made in the PreProduction workspace, along with all committed data from non-version-enabled tables belonging to the Live workspace. In addition it can see data from version-enabled tables in Live as they were when the PreProduction workspace was created. Once a workspace is refreshed, all changes can be cascaded down the hierarchy.
Workspace Manager makes only a copy of row it is changed ,which reduce hardware , software and time needed to manage multiple version of data in different schemas .A workspace is a virtual environment not physical storage.The default workspace is called LIVE.
Main concepts used for workspace are Instead of Triggers and Context .
For More On WorkSpace
To get Version
SELECT dbms_wm.getversion FROM dual;
To create Workspace
begin
dbms_wm.createworkspace('B_focus_1');
end;
select workspace, parent_workspace from user_workspaces;
To move to workspace
begin
dbms_wm.gotoworkspace('B_focus_1');
end;
To enable versoning for a table
begin
dbms_wm.enableversioning (table_name,hist);
end;
1)The length of a table name must not exceed 25 characters. The name is not case sensitive
2) Hist
NONE: No modifications to the table are tracked. (This is the default.)
VIEW_W_OVERWRITE: The with overwrite (W_OVERWRITE) option: A view named
VIEW_WO_OVERWRITE: The without overwrite (WO_OVERWRITE) option: A view named
If the table is version-enabled with the VIEW_WO_OVERWRITE hist option specified, this option can later be disabled and re-enabled by calling the SetWoOverwriteOFF Procedure and SetWoOverwriteON Procedure.
begin
DBMS_WM.SetWoOverwriteOFF();
end;
This procedure enables the VIEW_WO_OVERWRITE history option that had been disabled by the SetWoOverwriteOFF Procedure.
begin
DBMS_WM.SetWoOverwriteON();
end;
---------------------------------------
a)Only the owner of a table can enable versioning on the table.
b)Tables that are version-enabled and users that own version-enabled tables cannot be deleted. You must first disable versioning on the relevant table or tables.
c)Tables owned by SYS cannot be version-enabled.
d)DDL operations are not allowed on version-enabled tables.
e)Index-organized tables cannot be version-enabled.
f)Object tables cannot be version-enabled.
g)A table with one or more columns of LONG data type cannot be version-enabled.
------------------------------------------------------------
Example
begin
dbms_wm.enableversioning ('TEST');
end;
This will rename the TEST table to TEST_LT(LT stands for Long Transaction ie:Completes over days or week ) and create a view called TEST (which contains original data for more detail refer script of view) addition to this 9 other views will be created.The view uses instead-of triggers to perform all operations against the version enabled table. This hides a lot of the versioning mechanism from the users.
The TEST_LT table has the following additional columns:
VERSION NOT NULL NUMBER(38)
NEXTVER VARCHAR2(500)
DELSTATUS NUMBER(38)
LTLOCK VARCHAR2(100)
Values for following tables when table is version enabled (0,-1,10,!O!)
Test_MV (Materialized view) View it contains data ;which the field is not affected ;with two extra fields WM_MODIFIEDBY and WM_OPTYPE
Test_base view contains the field of original table in addition RID,version,nextver,delstatus,ltlock
Test_BPKC contains fields Rowids of child,parent and base ,childstate ,parentstate ,DS and VER of child,parent & base (ie : 12 fields) if we are in LIVE workspace there will not be an data in it because it is in parent state if it is in any of child workspace there will be data
Test_PKC contains all the fields of Text_BPKC excluding Firstchildver
TEST_HIST This view is created only if ; during table versioning (ie: enableversioning) if we supply hist parameter if hist parameter is NONE then this view will not be there to track history details .
IF active workspace is LIVE then TEST,TEST_BASE,TEST_MV view only have records
Test_conf (Conflict) view contains all fields in Test addition to those wm_workspace,wm_delted
To disable versoning
begin
dbms_wm.disableversioning ('TEST');
end;
To compress WorkSpace
begin
dbms_wm.compressworkspace('LIVE');
end;
To view curent workspace
SELECT DBMS_WM.getworkspace FROM DUAL;
To view versionenabled tables
select * from wmsys.wm$table_parvers_view
SELECT * FROM user_wm_versioned_tables;
select * from wmsys.
select * from wmsys.
select * from wmsys.
select * from wmsys.
You should be in a workspace other than LIVE then only we get data from this view ; because for LIVE workspace is parent of .
select * from wmsys.
select * from wmsys.
select * from wmsys.
select * from wmsys.
To get savepoint
--------------------------------------------------------
Mar 13, 2009
Insertion with condition
If there is a table with fields rt (number) which is a primary key and DF varchar2.If there r 10 records and first 5 records r deleted then when inserting records it want to start from 1 and then increment after each insert .
create table DF(DF VARCHAR2(3000),RT NUMBER(2) not null);
alter table DF add constraint E primary key (RT);
insert into df(rt,df)
with
all_numbers as (select level num from dual connect by level <=99),
available_number as (select num,rownum line from
(select num from all_numbers minus select rt from df order by 1) order by num )
select num,'B-'||rownum from available_number where rownum <=10;
----------------------------------------------------------------------
create table DF(DF VARCHAR2(3000),RT NUMBER(2) not null);
alter table DF add constraint E primary key (RT);
insert into df(rt,df)
with
all_numbers as (select level num from dual connect by level <=99),
available_number as (select num,rownum line from
(select num from all_numbers minus select rt from df order by 1) order by num )
select num,'B-'||rownum from available_number where rownum <=10;
----------------------------------------------------------------------
Subscribe to:
Posts (Atom)