- 浏览: 47033 次
- 性别:
- 来自: 北京
最新评论
(172)上配置用于源的UDB_V2和UDB的tnsname.ora,以便直接在172上分别操控源和目的:
UDB_V2 =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.10.91)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = smsc)
)
)
UDB =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost.localdomain)(PORT = 1522))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = udb)
)
)
1,在源数据库上登录,查询
sqlplus udb_v2/udb@udb
执行:
select * from global_name;
得到
SMSC.REGRESS.RDBMS.DEV.US.ORACLE.COM , 记住数据库名:smsc
2,在目的数据库上登录:
sqlplus 'udb_v2/udb123#@UDB'
执行:
create database link smsc connect to udb_v2 identified by udb using 'test';
建立dblink
其中smsc为源数据库的数据库名,test为服务器端的tnsname!
test为tnsname.ora中连接源的服务名
检查下dblink是否可用:
select count(*) from device@smsc;
看是否能查到结果
3,再源数据库上登录
建立快照日志:
create snapshot log on userid;
create snapshot log on service;
4,在目的数据库上登录
建立快照,会很长时间,这时数据会导入
create snapshot sn_userid as select * from userid@smsc;
create snapshot sn_service as select * from service@smsc;
将快照插入userid和service表中
insert into userid select * from sn_userid;
insert into service select * from sn_service;
建立快照的触发器
sn_userid:
CREATE OR REPLACE TRIGGER UDB_V2.TRI_SN_USERID_AFR
AFTER DELETE OR INSERT OR UPDATE
ON UDB_V2.SN_USERID REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
declare
tmp_id varchar2(40);
tmp_ss integer;
begin
dbms_output.put_line('begin triger on sn_userid');
if inserting then
dbms_output.put_line('insert');
for p in(
select user_id into tmp_id from userid where user_id=:new.user_id
)
loop
tmp_id:=p.user_id;
end loop;
if (tmp_id is null) then
INSERT INTO USERID
(
USER_ID, PASSWD, USERID_STATUS,
CREATE_TIME, EXT_PASSWD, TMP_PASSWD,
TMP_CREATE_TIME, TMP_EXIPRATION_TIME, OTP_TOKENID,
SEX, EMAIL, LAST_MODIFY_TIME,
PROVINCE_NO, CITY_NO, CERTIFICATE_TYPE,
CERTIFICATE_NO, PAY_TYPE, PRE_PAY_SYSTEM_NO,
PAY_EFFECT_MODE, PAY_EFFECT_TIME, SRC_DEVICE_NO,
ACTIVE_STATUS, UPDATE_FLAG, USERID_TYPE,
AREACODE, CUSTOMERID, USERNAME,
SERSET_TYPE, BINDING_TELE_NO, P_USERID,
ALIAS, ACCOUNT_ACT, ACCOUNT_TYPE,
ACCOUNT_STATE, ACCOUNT_RETRY, ACCOUNT_RETRYTIME,
PASSWD_ACT, USERID_LOGIN_STATUS, USERIDSTATUS_REFTIME,
MOBILE_PHONE, SSO_FLAG, UIM,
CUSTOMERFLAG, PASSWD2, P_USERID_PASSPORT,
USERID_STATUS_EXT
)
VALUES
(
:NEW.USER_ID, :NEW.PASSWD, :NEW.USERID_STATUS,
:NEW.CREATE_TIME, :NEW.EXT_PASSWD, :NEW.TMP_PASSWD,
:NEW.TMP_CREATE_TIME, :NEW.TMP_EXIPRATION_TIME, :NEW.OTP_TOKENID,
:NEW.SEX, :NEW.EMAIL, :NEW.LAST_MODIFY_TIME,
:NEW.PROVINCE_NO, :NEW.CITY_NO, :NEW.CERTIFICATE_TYPE,
:NEW.CERTIFICATE_NO, :NEW.PAY_TYPE, :NEW.PRE_PAY_SYSTEM_NO,
:NEW.PAY_EFFECT_MODE, :NEW.PAY_EFFECT_TIME, :NEW.SRC_DEVICE_NO,
:NEW.ACTIVE_STATUS, :NEW.UPDATE_FLAG, :NEW.USERID_TYPE,
:NEW.AREACODE, :NEW.CUSTOMERID, :NEW.USERNAME,
:NEW.SERSET_TYPE, :NEW.BINDING_TELE_NO, :NEW.P_USERID,
:NEW.ALIAS, :NEW.ACCOUNT_ACT, :NEW.ACCOUNT_TYPE,
:NEW.ACCOUNT_STATE, :NEW.ACCOUNT_RETRY, :NEW.ACCOUNT_RETRYTIME,
:NEW.PASSWD_ACT, :NEW.USERID_LOGIN_STATUS, :NEW.USERIDSTATUS_REFTIME,
:NEW.MOBILE_PHONE, :NEW.SSO_FLAG, :NEW.UIM,
:NEW.CUSTOMERFLAG, :NEW.PASSWD2,:NEW.P_USERID_PASSPORT,
:NEW.USERID_STATUS_EXT
);
end if;
end if;
if updating then
dbms_output.put_line('updated');
for p in(select * from userid where user_id=:OLD.user_id)
loop
if (
(p.PASSWD != :new.PASSWD)
OR (p.USERID_STATUS != :new.USERID_STATUS)
OR (p.CREATE_TIME != :new.CREATE_TIME)
OR (p.EXT_PASSWD != :new.EXT_PASSWD)
OR (p.TMP_PASSWD != :new.TMP_PASSWD)
OR (p.TMP_EXIPRATION_TIME != :new.TMP_EXIPRATION_TIME)
OR (p.OTP_TOKENID != :new.OTP_TOKENID)
OR (p.SEX != :new.SEX)
OR (p.EMAIL != :new.EMAIL)
OR (p.LAST_MODIFY_TIME != :new.LAST_MODIFY_TIME)
OR (p.PROVINCE_NO != :new.PROVINCE_NO)
OR (p.CITY_NO != :new.CITY_NO)
OR (p.CERTIFICATE_TYPE != :new.CERTIFICATE_TYPE)
OR (p.CERTIFICATE_NO != :new.CERTIFICATE_NO)
OR (p.PAY_TYPE != :new.PAY_TYPE)
OR (p.PRE_PAY_SYSTEM_NO != :new.PRE_PAY_SYSTEM_NO)
OR (p.PAY_EFFECT_MODE != :new.PAY_EFFECT_MODE)
OR (p.PAY_EFFECT_TIME != :new.PAY_EFFECT_TIME)
OR (p.SRC_DEVICE_NO != :new.SRC_DEVICE_NO)
OR (p.ACTIVE_STATUS != :new.ACTIVE_STATUS)
OR (p.UPDATE_FLAG != :new.UPDATE_FLAG)
OR (p.USERID_TYPE != :new.USERID_TYPE)
OR (p.AREACODE != :new.AREACODE)
OR (p.CUSTOMERID != :new.CUSTOMERID)
OR (p.USERNAME != :new.USERNAME)
OR (p.SERSET_TYPE != :new.SERSET_TYPE)
OR (p.BINDING_TELE_NO != :new.BINDING_TELE_NO)
OR (p.P_USERID != :new.P_USERID)
OR (p.ALIAS != :new.ALIAS)
OR (p.ACCOUNT_ACT != :new.ACCOUNT_ACT)
OR (p.ACCOUNT_TYPE != :new.ACCOUNT_TYPE)
OR (p.ACCOUNT_STATE != :new.ACCOUNT_STATE)
OR (p.ACCOUNT_RETRY != :new.ACCOUNT_RETRY)
OR (p.ACCOUNT_RETRYTIME != :new.ACCOUNT_RETRYTIME)
OR (p.PASSWD_ACT != :new.PASSWD_ACT)
OR (p.USERID_LOGIN_STATUS != :new.USERID_LOGIN_STATUS)
OR (p.USERIDSTATUS_REFTIME != :new.USERIDSTATUS_REFTIME)
OR (p.MOBILE_PHONE != :new.MOBILE_PHONE)
OR (p.SSO_FLAG != :new.SSO_FLAG)
OR (p.UIM != :new.UIM)
OR (p.CUSTOMERFLAG != :new.CUSTOMERFLAG)
OR (p.PASSWD2 != :new.PASSWD2)
OR (p.P_USERID_PASSPORT != :new.P_USERID_PASSPORT)
OR (p.USERID_STATUS_EXT != :new.USERID_STATUS_EXT)
) then
UPDATE USERID
SET USER_ID = :new.USER_ID,
PASSWD = :new.PASSWD,
USERID_STATUS = :new.USERID_STATUS,
CREATE_TIME = :new.CREATE_TIME,
EXT_PASSWD = :new.EXT_PASSWD,
TMP_PASSWD = :new.TMP_PASSWD,
TMP_CREATE_TIME = :new.TMP_CREATE_TIME,
TMP_EXIPRATION_TIME = :new.TMP_EXIPRATION_TIME,
OTP_TOKENID = :new.OTP_TOKENID,
SEX = :new.SEX,
EMAIL = :new.EMAIL,
LAST_MODIFY_TIME = :new.LAST_MODIFY_TIME,
PROVINCE_NO = :new.PROVINCE_NO,
CITY_NO = :new.CITY_NO,
CERTIFICATE_TYPE = :new.CERTIFICATE_TYPE,
CERTIFICATE_NO = :new.CERTIFICATE_NO,
PAY_TYPE = :new.PAY_TYPE,
PRE_PAY_SYSTEM_NO = :new.PRE_PAY_SYSTEM_NO,
PAY_EFFECT_MODE = :new.PAY_EFFECT_MODE,
PAY_EFFECT_TIME = :new.PAY_EFFECT_TIME,
SRC_DEVICE_NO = :new.SRC_DEVICE_NO,
ACTIVE_STATUS = :new.ACTIVE_STATUS,
UPDATE_FLAG = :new.UPDATE_FLAG,
USERID_TYPE = :new.USERID_TYPE,
AREACODE = :new.AREACODE,
CUSTOMERID = :new.CUSTOMERID,
USERNAME = :new.USERNAME,
SERSET_TYPE = :new.SERSET_TYPE,
BINDING_TELE_NO = :new.BINDING_TELE_NO,
P_USERID = :new.P_USERID,
ALIAS = :new.ALIAS,
ACCOUNT_ACT = :new.ACCOUNT_ACT,
ACCOUNT_TYPE = :new.ACCOUNT_TYPE,
ACCOUNT_STATE = :new.ACCOUNT_STATE,
ACCOUNT_RETRY = :new.ACCOUNT_RETRY,
ACCOUNT_RETRYTIME = :new.ACCOUNT_RETRYTIME,
PASSWD_ACT = :new.PASSWD_ACT,
USERID_LOGIN_STATUS = :new.USERID_LOGIN_STATUS,
USERIDSTATUS_REFTIME = :new.USERIDSTATUS_REFTIME,
MOBILE_PHONE = :new.MOBILE_PHONE,
SSO_FLAG = :new.SSO_FLAG,
UIM = :new.UIM,
CUSTOMERFLAG = :new.CUSTOMERFLAG,
PASSWD2 = :new.PASSWD2,
P_USERID_PASSPORT = :new.P_USERID_PASSPORT,
USERID_STATUS_EXT = :new.USERID_STATUS_EXT
WHERE USER_ID = :new.USER_ID
;
end if;
end loop;
end if;
if deleting then
dbms_output.put_line('deleted');
delete from service where user_id=:old.user_id;
delete from userid where user_id=:old.user_id;
end if;
dbms_output.put_line('end triger on sn_userid');
end TRI_SN_USERID_AFR;
/
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
service:
CREATE OR REPLACE TRIGGER UDB_V2.TRI_SN_SERVICE_AFR
AFTER DELETE OR INSERT OR UPDATE
ON UDB_V2.SN_SERVICE REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
declare
tmp_ss INTEGER;
begin
dbms_output.put_line('begin triger on sn_service');
if inserting then
dbms_output.put_line('insert');
for p in(
select SS_INDEX into tmp_ss from SERVICE where SS_INDEX=:new.SS_INDEX
)
loop
tmp_ss:=p.SS_INDEX;
end loop;
if (tmp_ss is null) then
dbms_output.put_line('in insert service');
INSERT INTO SERVICE (
SS_INDEX, USER_ID, SS_PASSWORD,
SS_STATUS, SRC_DEVICE_NO, CREATE_TIME,
LAST_MODIFY_TIME, AUTH_SRC, REG_EFFECT_MODE,
REG_EFFECT_TIME, BIND_TYPE, BIND_EFFECT_MODE,
BIND_EFFECT_TIME, SS_TYPE, USERID_SS_LOGIN_STATUS,
SS_ID, SS_PASSWD_ACT, SS_ACTIVE_FLAG
)
VALUES (
:NEW.SS_INDEX, :NEW.USER_ID, :NEW.SS_PASSWORD,
:NEW.SS_STATUS, :NEW.SRC_DEVICE_NO, :NEW.CREATE_TIME,
:NEW.LAST_MODIFY_TIME, :NEW.AUTH_SRC, :NEW.REG_EFFECT_MODE,
:NEW.REG_EFFECT_TIME, :NEW.BIND_TYPE, :NEW.BIND_EFFECT_MODE,
:NEW.BIND_EFFECT_TIME, :NEW.SS_TYPE, :NEW.USERID_SS_LOGIN_STATUS ,
:NEW.SS_ID, :NEW.SS_PASSWD_ACT, :NEW.SS_ACTIVE_FLAG
);
end if;
end if;
if updating then
dbms_output.put_line('updated');
for p in(select * from SERVICE where SS_INDEX=:OLD.SS_INDEX)
loop
if (
(P.USER_ID != :NEW.USER_ID)
OR (P.SS_PASSWORD != :NEW.SS_PASSWORD)
OR (P.SS_STATUS != :NEW.SS_STATUS)
OR (P.SRC_DEVICE_NO != :NEW.SRC_DEVICE_NO)
OR (P.CREATE_TIME != :NEW.CREATE_TIME)
OR (P.LAST_MODIFY_TIME != :NEW.LAST_MODIFY_TIME)
OR (P.AUTH_SRC != :NEW.AUTH_SRC)
OR (P.REG_EFFECT_MODE != :NEW.REG_EFFECT_MODE)
OR (P.REG_EFFECT_TIME != :NEW.REG_EFFECT_TIME)
OR (P.BIND_TYPE != :NEW.BIND_TYPE)
OR (P.BIND_EFFECT_MODE != :NEW.BIND_EFFECT_MODE)
OR (P.BIND_EFFECT_TIME != :NEW.BIND_EFFECT_TIME)
OR (P.SS_TYPE != :NEW.SS_TYPE)
OR (P.USERID_SS_LOGIN_STATUS != :NEW.USERID_SS_LOGIN_STATUS)
OR (P.SS_ID != :NEW.SS_ID)
OR (P.SS_PASSWD_ACT != :NEW.SS_PASSWD_ACT)
OR (P.SS_ACTIVE_FLAG != :NEW.SS_ACTIVE_FLAG)
)
then
UPDATE SERVICE
SET
SS_INDEX = :NEW.SS_INDEX,
USER_ID = :NEW.USER_ID,
SS_PASSWORD = :NEW.SS_PASSWORD,
SS_STATUS = :NEW.SS_STATUS,
SRC_DEVICE_NO = :NEW.SRC_DEVICE_NO,
CREATE_TIME = :NEW.CREATE_TIME,
LAST_MODIFY_TIME = :NEW.LAST_MODIFY_TIME,
AUTH_SRC = :NEW.AUTH_SRC,
REG_EFFECT_MODE = :NEW.REG_EFFECT_MODE,
REG_EFFECT_TIME = :NEW.REG_EFFECT_TIME,
BIND_TYPE = :NEW.BIND_TYPE,
BIND_EFFECT_MODE = :NEW.BIND_EFFECT_MODE,
BIND_EFFECT_TIME = :NEW.BIND_EFFECT_TIME,
SS_TYPE = :NEW.SS_TYPE,
USERID_SS_LOGIN_STATUS = :NEW.USERID_SS_LOGIN_STATUS,
SS_ID = :NEW.SS_ID,
SS_PASSWD_ACT = :NEW.SS_PASSWD_ACT,
SS_ACTIVE_FLAG = :NEW.SS_ACTIVE_FLAG
WHERE SS_INDEX = :new.SS_INDEX
;
end if;
end loop;
end if;
if deleting then
dbms_output.put_line('deleted');
delete from service where SS_INDEX=:old.SS_INDEX;
end if;
dbms_output.put_line('end triger on sn_service');
end TRI_SN_SERVICE_AFR;
/
修改快照刷新时间
Alter snapshot sn_userid refresh fast Start with sysdate+2/(24) next sysdate+1/(24);
Alter snapshot sn_service refresh fast Start with sysdate+2/(24) next sysdate+1/(24);
首次刷新在30秒之后,以后每分钟刷新一次
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
附件:
1.查看快照最后一次刷新时间
SELECT NAME,LAST_REFRESH FROM ALL_SNAPSHOT_REFRESH_TIMES;
2.查看快照下次执行时间
select last_date,next_date,what from user_jobs order by next_date;
3.手动执行更新
EXEC DBMS_SNAPSHOT.REFRESH ('sn_service','F');
手动刷新方式1
begin
dbms_refresh.refresh('sn_service');
end;
手动刷新方式2
EXEC DBMS_SNAPSHOT.REFRESH('sn_service','F'); //第一个参数是快照名,第二个参数 F 是快速刷新 C 是完全刷新.
4.删除快照日志(在源上)
drop snapshot log on userid;
drop snapshot log on service;
5删除掉快照(在目的上)
drop snapshot sn_userid;
drop snapshot sn_service;
UDB_V2 =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.10.91)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = smsc)
)
)
UDB =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = localhost.localdomain)(PORT = 1522))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = udb)
)
)
1,在源数据库上登录,查询
sqlplus udb_v2/udb@udb
执行:
select * from global_name;
得到
SMSC.REGRESS.RDBMS.DEV.US.ORACLE.COM , 记住数据库名:smsc
2,在目的数据库上登录:
sqlplus 'udb_v2/udb123#@UDB'
执行:
create database link smsc connect to udb_v2 identified by udb using 'test';
建立dblink
其中smsc为源数据库的数据库名,test为服务器端的tnsname!
test为tnsname.ora中连接源的服务名
检查下dblink是否可用:
select count(*) from device@smsc;
看是否能查到结果
3,再源数据库上登录
建立快照日志:
create snapshot log on userid;
create snapshot log on service;
4,在目的数据库上登录
建立快照,会很长时间,这时数据会导入
create snapshot sn_userid as select * from userid@smsc;
create snapshot sn_service as select * from service@smsc;
将快照插入userid和service表中
insert into userid select * from sn_userid;
insert into service select * from sn_service;
建立快照的触发器
sn_userid:
CREATE OR REPLACE TRIGGER UDB_V2.TRI_SN_USERID_AFR
AFTER DELETE OR INSERT OR UPDATE
ON UDB_V2.SN_USERID REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
declare
tmp_id varchar2(40);
tmp_ss integer;
begin
dbms_output.put_line('begin triger on sn_userid');
if inserting then
dbms_output.put_line('insert');
for p in(
select user_id into tmp_id from userid where user_id=:new.user_id
)
loop
tmp_id:=p.user_id;
end loop;
if (tmp_id is null) then
INSERT INTO USERID
(
USER_ID, PASSWD, USERID_STATUS,
CREATE_TIME, EXT_PASSWD, TMP_PASSWD,
TMP_CREATE_TIME, TMP_EXIPRATION_TIME, OTP_TOKENID,
SEX, EMAIL, LAST_MODIFY_TIME,
PROVINCE_NO, CITY_NO, CERTIFICATE_TYPE,
CERTIFICATE_NO, PAY_TYPE, PRE_PAY_SYSTEM_NO,
PAY_EFFECT_MODE, PAY_EFFECT_TIME, SRC_DEVICE_NO,
ACTIVE_STATUS, UPDATE_FLAG, USERID_TYPE,
AREACODE, CUSTOMERID, USERNAME,
SERSET_TYPE, BINDING_TELE_NO, P_USERID,
ALIAS, ACCOUNT_ACT, ACCOUNT_TYPE,
ACCOUNT_STATE, ACCOUNT_RETRY, ACCOUNT_RETRYTIME,
PASSWD_ACT, USERID_LOGIN_STATUS, USERIDSTATUS_REFTIME,
MOBILE_PHONE, SSO_FLAG, UIM,
CUSTOMERFLAG, PASSWD2, P_USERID_PASSPORT,
USERID_STATUS_EXT
)
VALUES
(
:NEW.USER_ID, :NEW.PASSWD, :NEW.USERID_STATUS,
:NEW.CREATE_TIME, :NEW.EXT_PASSWD, :NEW.TMP_PASSWD,
:NEW.TMP_CREATE_TIME, :NEW.TMP_EXIPRATION_TIME, :NEW.OTP_TOKENID,
:NEW.SEX, :NEW.EMAIL, :NEW.LAST_MODIFY_TIME,
:NEW.PROVINCE_NO, :NEW.CITY_NO, :NEW.CERTIFICATE_TYPE,
:NEW.CERTIFICATE_NO, :NEW.PAY_TYPE, :NEW.PRE_PAY_SYSTEM_NO,
:NEW.PAY_EFFECT_MODE, :NEW.PAY_EFFECT_TIME, :NEW.SRC_DEVICE_NO,
:NEW.ACTIVE_STATUS, :NEW.UPDATE_FLAG, :NEW.USERID_TYPE,
:NEW.AREACODE, :NEW.CUSTOMERID, :NEW.USERNAME,
:NEW.SERSET_TYPE, :NEW.BINDING_TELE_NO, :NEW.P_USERID,
:NEW.ALIAS, :NEW.ACCOUNT_ACT, :NEW.ACCOUNT_TYPE,
:NEW.ACCOUNT_STATE, :NEW.ACCOUNT_RETRY, :NEW.ACCOUNT_RETRYTIME,
:NEW.PASSWD_ACT, :NEW.USERID_LOGIN_STATUS, :NEW.USERIDSTATUS_REFTIME,
:NEW.MOBILE_PHONE, :NEW.SSO_FLAG, :NEW.UIM,
:NEW.CUSTOMERFLAG, :NEW.PASSWD2,:NEW.P_USERID_PASSPORT,
:NEW.USERID_STATUS_EXT
);
end if;
end if;
if updating then
dbms_output.put_line('updated');
for p in(select * from userid where user_id=:OLD.user_id)
loop
if (
(p.PASSWD != :new.PASSWD)
OR (p.USERID_STATUS != :new.USERID_STATUS)
OR (p.CREATE_TIME != :new.CREATE_TIME)
OR (p.EXT_PASSWD != :new.EXT_PASSWD)
OR (p.TMP_PASSWD != :new.TMP_PASSWD)
OR (p.TMP_EXIPRATION_TIME != :new.TMP_EXIPRATION_TIME)
OR (p.OTP_TOKENID != :new.OTP_TOKENID)
OR (p.SEX != :new.SEX)
OR (p.EMAIL != :new.EMAIL)
OR (p.LAST_MODIFY_TIME != :new.LAST_MODIFY_TIME)
OR (p.PROVINCE_NO != :new.PROVINCE_NO)
OR (p.CITY_NO != :new.CITY_NO)
OR (p.CERTIFICATE_TYPE != :new.CERTIFICATE_TYPE)
OR (p.CERTIFICATE_NO != :new.CERTIFICATE_NO)
OR (p.PAY_TYPE != :new.PAY_TYPE)
OR (p.PRE_PAY_SYSTEM_NO != :new.PRE_PAY_SYSTEM_NO)
OR (p.PAY_EFFECT_MODE != :new.PAY_EFFECT_MODE)
OR (p.PAY_EFFECT_TIME != :new.PAY_EFFECT_TIME)
OR (p.SRC_DEVICE_NO != :new.SRC_DEVICE_NO)
OR (p.ACTIVE_STATUS != :new.ACTIVE_STATUS)
OR (p.UPDATE_FLAG != :new.UPDATE_FLAG)
OR (p.USERID_TYPE != :new.USERID_TYPE)
OR (p.AREACODE != :new.AREACODE)
OR (p.CUSTOMERID != :new.CUSTOMERID)
OR (p.USERNAME != :new.USERNAME)
OR (p.SERSET_TYPE != :new.SERSET_TYPE)
OR (p.BINDING_TELE_NO != :new.BINDING_TELE_NO)
OR (p.P_USERID != :new.P_USERID)
OR (p.ALIAS != :new.ALIAS)
OR (p.ACCOUNT_ACT != :new.ACCOUNT_ACT)
OR (p.ACCOUNT_TYPE != :new.ACCOUNT_TYPE)
OR (p.ACCOUNT_STATE != :new.ACCOUNT_STATE)
OR (p.ACCOUNT_RETRY != :new.ACCOUNT_RETRY)
OR (p.ACCOUNT_RETRYTIME != :new.ACCOUNT_RETRYTIME)
OR (p.PASSWD_ACT != :new.PASSWD_ACT)
OR (p.USERID_LOGIN_STATUS != :new.USERID_LOGIN_STATUS)
OR (p.USERIDSTATUS_REFTIME != :new.USERIDSTATUS_REFTIME)
OR (p.MOBILE_PHONE != :new.MOBILE_PHONE)
OR (p.SSO_FLAG != :new.SSO_FLAG)
OR (p.UIM != :new.UIM)
OR (p.CUSTOMERFLAG != :new.CUSTOMERFLAG)
OR (p.PASSWD2 != :new.PASSWD2)
OR (p.P_USERID_PASSPORT != :new.P_USERID_PASSPORT)
OR (p.USERID_STATUS_EXT != :new.USERID_STATUS_EXT)
) then
UPDATE USERID
SET USER_ID = :new.USER_ID,
PASSWD = :new.PASSWD,
USERID_STATUS = :new.USERID_STATUS,
CREATE_TIME = :new.CREATE_TIME,
EXT_PASSWD = :new.EXT_PASSWD,
TMP_PASSWD = :new.TMP_PASSWD,
TMP_CREATE_TIME = :new.TMP_CREATE_TIME,
TMP_EXIPRATION_TIME = :new.TMP_EXIPRATION_TIME,
OTP_TOKENID = :new.OTP_TOKENID,
SEX = :new.SEX,
EMAIL = :new.EMAIL,
LAST_MODIFY_TIME = :new.LAST_MODIFY_TIME,
PROVINCE_NO = :new.PROVINCE_NO,
CITY_NO = :new.CITY_NO,
CERTIFICATE_TYPE = :new.CERTIFICATE_TYPE,
CERTIFICATE_NO = :new.CERTIFICATE_NO,
PAY_TYPE = :new.PAY_TYPE,
PRE_PAY_SYSTEM_NO = :new.PRE_PAY_SYSTEM_NO,
PAY_EFFECT_MODE = :new.PAY_EFFECT_MODE,
PAY_EFFECT_TIME = :new.PAY_EFFECT_TIME,
SRC_DEVICE_NO = :new.SRC_DEVICE_NO,
ACTIVE_STATUS = :new.ACTIVE_STATUS,
UPDATE_FLAG = :new.UPDATE_FLAG,
USERID_TYPE = :new.USERID_TYPE,
AREACODE = :new.AREACODE,
CUSTOMERID = :new.CUSTOMERID,
USERNAME = :new.USERNAME,
SERSET_TYPE = :new.SERSET_TYPE,
BINDING_TELE_NO = :new.BINDING_TELE_NO,
P_USERID = :new.P_USERID,
ALIAS = :new.ALIAS,
ACCOUNT_ACT = :new.ACCOUNT_ACT,
ACCOUNT_TYPE = :new.ACCOUNT_TYPE,
ACCOUNT_STATE = :new.ACCOUNT_STATE,
ACCOUNT_RETRY = :new.ACCOUNT_RETRY,
ACCOUNT_RETRYTIME = :new.ACCOUNT_RETRYTIME,
PASSWD_ACT = :new.PASSWD_ACT,
USERID_LOGIN_STATUS = :new.USERID_LOGIN_STATUS,
USERIDSTATUS_REFTIME = :new.USERIDSTATUS_REFTIME,
MOBILE_PHONE = :new.MOBILE_PHONE,
SSO_FLAG = :new.SSO_FLAG,
UIM = :new.UIM,
CUSTOMERFLAG = :new.CUSTOMERFLAG,
PASSWD2 = :new.PASSWD2,
P_USERID_PASSPORT = :new.P_USERID_PASSPORT,
USERID_STATUS_EXT = :new.USERID_STATUS_EXT
WHERE USER_ID = :new.USER_ID
;
end if;
end loop;
end if;
if deleting then
dbms_output.put_line('deleted');
delete from service where user_id=:old.user_id;
delete from userid where user_id=:old.user_id;
end if;
dbms_output.put_line('end triger on sn_userid');
end TRI_SN_USERID_AFR;
/
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
service:
CREATE OR REPLACE TRIGGER UDB_V2.TRI_SN_SERVICE_AFR
AFTER DELETE OR INSERT OR UPDATE
ON UDB_V2.SN_SERVICE REFERENCING NEW AS NEW OLD AS OLD
FOR EACH ROW
declare
tmp_ss INTEGER;
begin
dbms_output.put_line('begin triger on sn_service');
if inserting then
dbms_output.put_line('insert');
for p in(
select SS_INDEX into tmp_ss from SERVICE where SS_INDEX=:new.SS_INDEX
)
loop
tmp_ss:=p.SS_INDEX;
end loop;
if (tmp_ss is null) then
dbms_output.put_line('in insert service');
INSERT INTO SERVICE (
SS_INDEX, USER_ID, SS_PASSWORD,
SS_STATUS, SRC_DEVICE_NO, CREATE_TIME,
LAST_MODIFY_TIME, AUTH_SRC, REG_EFFECT_MODE,
REG_EFFECT_TIME, BIND_TYPE, BIND_EFFECT_MODE,
BIND_EFFECT_TIME, SS_TYPE, USERID_SS_LOGIN_STATUS,
SS_ID, SS_PASSWD_ACT, SS_ACTIVE_FLAG
)
VALUES (
:NEW.SS_INDEX, :NEW.USER_ID, :NEW.SS_PASSWORD,
:NEW.SS_STATUS, :NEW.SRC_DEVICE_NO, :NEW.CREATE_TIME,
:NEW.LAST_MODIFY_TIME, :NEW.AUTH_SRC, :NEW.REG_EFFECT_MODE,
:NEW.REG_EFFECT_TIME, :NEW.BIND_TYPE, :NEW.BIND_EFFECT_MODE,
:NEW.BIND_EFFECT_TIME, :NEW.SS_TYPE, :NEW.USERID_SS_LOGIN_STATUS ,
:NEW.SS_ID, :NEW.SS_PASSWD_ACT, :NEW.SS_ACTIVE_FLAG
);
end if;
end if;
if updating then
dbms_output.put_line('updated');
for p in(select * from SERVICE where SS_INDEX=:OLD.SS_INDEX)
loop
if (
(P.USER_ID != :NEW.USER_ID)
OR (P.SS_PASSWORD != :NEW.SS_PASSWORD)
OR (P.SS_STATUS != :NEW.SS_STATUS)
OR (P.SRC_DEVICE_NO != :NEW.SRC_DEVICE_NO)
OR (P.CREATE_TIME != :NEW.CREATE_TIME)
OR (P.LAST_MODIFY_TIME != :NEW.LAST_MODIFY_TIME)
OR (P.AUTH_SRC != :NEW.AUTH_SRC)
OR (P.REG_EFFECT_MODE != :NEW.REG_EFFECT_MODE)
OR (P.REG_EFFECT_TIME != :NEW.REG_EFFECT_TIME)
OR (P.BIND_TYPE != :NEW.BIND_TYPE)
OR (P.BIND_EFFECT_MODE != :NEW.BIND_EFFECT_MODE)
OR (P.BIND_EFFECT_TIME != :NEW.BIND_EFFECT_TIME)
OR (P.SS_TYPE != :NEW.SS_TYPE)
OR (P.USERID_SS_LOGIN_STATUS != :NEW.USERID_SS_LOGIN_STATUS)
OR (P.SS_ID != :NEW.SS_ID)
OR (P.SS_PASSWD_ACT != :NEW.SS_PASSWD_ACT)
OR (P.SS_ACTIVE_FLAG != :NEW.SS_ACTIVE_FLAG)
)
then
UPDATE SERVICE
SET
SS_INDEX = :NEW.SS_INDEX,
USER_ID = :NEW.USER_ID,
SS_PASSWORD = :NEW.SS_PASSWORD,
SS_STATUS = :NEW.SS_STATUS,
SRC_DEVICE_NO = :NEW.SRC_DEVICE_NO,
CREATE_TIME = :NEW.CREATE_TIME,
LAST_MODIFY_TIME = :NEW.LAST_MODIFY_TIME,
AUTH_SRC = :NEW.AUTH_SRC,
REG_EFFECT_MODE = :NEW.REG_EFFECT_MODE,
REG_EFFECT_TIME = :NEW.REG_EFFECT_TIME,
BIND_TYPE = :NEW.BIND_TYPE,
BIND_EFFECT_MODE = :NEW.BIND_EFFECT_MODE,
BIND_EFFECT_TIME = :NEW.BIND_EFFECT_TIME,
SS_TYPE = :NEW.SS_TYPE,
USERID_SS_LOGIN_STATUS = :NEW.USERID_SS_LOGIN_STATUS,
SS_ID = :NEW.SS_ID,
SS_PASSWD_ACT = :NEW.SS_PASSWD_ACT,
SS_ACTIVE_FLAG = :NEW.SS_ACTIVE_FLAG
WHERE SS_INDEX = :new.SS_INDEX
;
end if;
end loop;
end if;
if deleting then
dbms_output.put_line('deleted');
delete from service where SS_INDEX=:old.SS_INDEX;
end if;
dbms_output.put_line('end triger on sn_service');
end TRI_SN_SERVICE_AFR;
/
修改快照刷新时间
Alter snapshot sn_userid refresh fast Start with sysdate+2/(24) next sysdate+1/(24);
Alter snapshot sn_service refresh fast Start with sysdate+2/(24) next sysdate+1/(24);
首次刷新在30秒之后,以后每分钟刷新一次
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
附件:
1.查看快照最后一次刷新时间
SELECT NAME,LAST_REFRESH FROM ALL_SNAPSHOT_REFRESH_TIMES;
2.查看快照下次执行时间
select last_date,next_date,what from user_jobs order by next_date;
3.手动执行更新
EXEC DBMS_SNAPSHOT.REFRESH ('sn_service','F');
手动刷新方式1
begin
dbms_refresh.refresh('sn_service');
end;
手动刷新方式2
EXEC DBMS_SNAPSHOT.REFRESH('sn_service','F'); //第一个参数是快照名,第二个参数 F 是快速刷新 C 是完全刷新.
4.删除快照日志(在源上)
drop snapshot log on userid;
drop snapshot log on service;
5删除掉快照(在目的上)
drop snapshot sn_userid;
drop snapshot sn_service;
相关推荐
Oracle数据库快照实现数据双向复制 本文将介绍如何利用Oracle数据库快照实现数据双向复制,以满足业务需求。首先,介绍了业务需求,即在医疗保险系统中,需要在多个地理位置之间实现数据共享和一致性。然后,介绍了...
对于Oracle数据库来说,它提供了多种手段来进行数据恢复,其中一种有效的方式就是利用快照(Snapshot)技术。本文将详细介绍如何利用Oracle的快照功能来恢复丢失的数据。 #### 二、Oracle快照简介 快照是一种记录...
Oracle数据库快照是一种高效的数据同步和查询优化工具,它允许用户在不同的数据库之间创建和维护一个数据的子集,这个子集就是快照。快照是基于源表或视图的查询结果,可以用于减少数据传输量,提高查询速度,并在...
在MySQL和Oracle这两个主流的数据库管理系统中,数据库快照功能的实现方式和特点存在显著差异。 MySQL和Oracle在数据库快照功能上各有优势。MySQL的快照功能简单易用,适合于Web应用和小型项目,而Oracle的快照功能...
### Oracle数据库服务器IO高的分析方案 #### 前言 在日常运维中,经常会遇到Oracle数据库服务器出现IO过高的情况,这种情况可能导致业务系统的响应速度变慢,甚至影响正常服务的提供。本文旨在深入探讨Oracle...
Oracle数据库中的快照是一种强大的工具,它允许用户创建一个数据库中的表或视图的本地副本,这个副本可以用来加速查询并保持与源数据的一致性。快照是通过捕获源表的特定时刻数据状态来实现的,它可以是快速刷新或...
oracle 数据恢复 误删恢复 111111111111111111111111111111111111111111111111111111111111111111111111
### Oracle数据库日常维护手册知识点详解 #### 一、检查数据库基本状况 在Oracle数据库的日常维护中,确保数据库的基本状况良好是首要任务。这包括检查Oracle实例状态、Oracle服务进程和Oracle监听状态。 ##### ...
Oracle数据库是全球广泛使用的大型关系型数据库管理系统,其在企业级应用中占据着重要的地位。本手册《Oracle数据库日常维护手册》将详细讲解如何有效地管理和维护Oracle数据库系统,确保其稳定、高效运行。 1. **...
【Oracle 数据库快照同步详解】 Oracle 数据库的快照同步技术是一种高效的数据共享和复制方法,它确保了源数据库和目标数据库之间的数据一致性。在快照同步中,源数据库通常执行数据变更操作,而目标数据库则通过...
### Oracle数据库进阶:高可用性、性能优化和备份恢复 在现代企业的信息化建设中,数据库作为核心的数据存储与管理工具扮演着至关重要的角色。Oracle数据库因其强大的功能、灵活性及可靠性而被广泛应用于各行各业。...
### Oracle数据库进阶-高可用性、性能优化和备份恢复 #### 一、Oracle数据库高可用性 在当今的企业环境中,数据库系统的高可用性(High Availability, HA)至关重要。Oracle数据库提供了一系列强大的高可用性解决...
11.5.2将物理Standby数据库转换为快照Standby数据库 11.5.3将快照Standby数据库转换为物理Standby数据库 11.6主备数据库切换 11.6.1 Switchover切换 11.6.2 Failover切换 11.7本章小结 第12章 RAC备份 12.1...
而源代码则包含了实现这些功能的具体逻辑,如连接Oracle数据库、执行SQL语句以创建数据库快照、处理备份文件等。 关于标签“delphi”、“oracle”、“备份”和“数据库”,我们可以推断出以下知识点: 1. **Delphi...
在Oracle数据库环境中,数据删除操作通常是不可逆的。然而,如果意外删除了重要数据,有几种方法可以帮助恢复这些数据。本文将深入探讨如何利用SQL和Oracle数据库特性来尝试恢复被DELETE语句删除的数据。 首先,...
Oracle数据库是全球广泛使用的大型关系型数据库管理系统之一,尤其在企业级应用中占据重要地位。本文将围绕"01-oracle数据库简单使用1"的主题,详细介绍Oracle数据库的基础知识,包括Oracle服务、数据库版本、用户...
Oracle数据库提供了多种方式来处理时间范围的数据,包括SQL查询、闪回功能和快照。下面我们将详细探讨这些知识点。 首先,SQL查询是获取特定时间段内数据的基础。在Oracle中,可以使用`BETWEEN`关键字来筛选特定...
"基于Oracle数据库海量数据的查询优化研究" 本文主要探讨了 Oracle 数据库海量数据的查询优化研究,通过对 Oracle 数据库的分析,讨论了分页查询技术、SQL 语句优化、索引技术等查询优化方法,并对 Oracle 数据库的...