您可以使用此存储过程在为上载而扫描事务日志之前添加自定义操作。
名称 | 值 | 说明 |
---|---|---|
starting log offset_n (in) |
数字 |
正在同步的每个预订的进度值。进度值是事务日志中的偏移量,到达该值时,即表示预订的所有数据均已上载完毕。每个正在同步的预订都有一个相应值。n 的编号从零开始。此值与 subscription_n 相匹配。例如,log offset_0 是 subscription_0 的偏移。 |
log scan retry (in) |
true | false |
如果这是为此同步进行的第一次事务日志扫描,则该值为 false,否则为 true。如果 MobiLink 服务器与 dbmlsync 中关于从何处开始扫描的信息不同,则进行两次日志扫描。 |
publication_n (in) |
发布 |
不建议使用。改用 subscription_n。正被同步的发布,其中 n 是一个整数。每个正在同步的发布都有一个 publication_n 条目。n 的编号从零开始。 |
MobiLink user (in) |
MobiLink 用户名 |
您正在为其进行同步的 MobiLink 用户。 |
script version (in) |
脚本版本名称 |
将用于同步的 MobiLink 脚本版本。 |
subscription_n (in) | 预订名称 | 正在进行同步的预订的名称,其中 n 是一个整数。每个正在同步的预订都有一个 subscription_n 条目。n 的编号从零开始。 |
如果以该名称命名的过程存在,那么它将在 dbmlsync 即将扫描事务日志以汇编上载时被调用。
对要包含到上载中的正在同步的表进行任何最后更改时,此挂接都是最佳选择。
该过程的操作将在执行后立即被提交。
任何具有 MANAGE REPLICATION 系统特权的用户都能创建挂接过程。但是,为了确保挂接能够访问用来将信息传入和传出挂接的 #hook_dict 表,挂接必须满足以下要求之一:
由具有 SELECT ANY TABLE 和 UPDATE ANY TABLE 系统特权的用户拥有。
使用 CREATE PROCEDURE 语句的 SQL SECURITY INVOKER 子句定义。
假定您使用下面的表记录远程数据库上的同步事件。
CREATE TABLE SyncLog ( "event_id" integer NOT NULL DEFAULT autoincrement , "event_time" timestamp NULL, "event_name" varchar(128) NOT NULL , "subs" varchar(1024) NULL , PRIMARY KEY ("event_id") ) |
以下代码为每个同步记录了日志扫描的开始信息。
CREATE PROCEDURE sp_hook_dbmlsync_logscan_begin () BEGIN DECLARE subs_list VARCHAR(1024); -- build a list of subscriptions being synchronized SELECT LIST(value) INTO subs_list FROM #hook_dict WHERE name LIKE 'subscription_%'; -- log the event INSERT INTO SyncLog(event_time, event_name, subs) VALUES( CURRENT TIMESTAMP, 'sp_hook_dbmlsync_logscan_begin', subs_list ); END |
![]() |
使用DocCommentXchange讨论此页。
|
版权 © 2013, SAP 股份公司或其关联公司. - SAP Sybase SQL Anywhere 16.0 |