MySQL触发器写入Sqlseever_sqlserver 触发器实例
實例1:update
USE [數據庫名稱]
GO
/****** Object: Trigger [dbo].[觸發器名稱] Script Date:
05/08/2014 12:40:25 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER
ON
GO
ALTER TRIGGER [dbo].[T_觸發器名稱] ON [dbo].[表名稱]
FOR
UPDATE
AS
DECLARE
@Id VARCHAR(32),
@remain_cost
DECIMAL(10,3),
@remain_flow DECIMAL(10,3),
@valid_time
DATETIME;
BEGIN
SET XACT_ABORT ON
BEGIN
TRANSACTION
--SELECT @Id = customer_no, @remain_cost = Balance,@remain_flow =
(MAX_VOLUME - USED_VOLUME) FROM INSERTED;
--insert
openrowset(‘MSDASQL‘,‘smysql‘;‘root‘;‘123456‘,‘select * from
mysql_authon.Consumer ‘) values(@Id,......)
SELECT @Id = customer_no,
@remain_cost = Balance,@remain_flow = (MAX_VOLUME - USED_VOLUME) FROM
INSERTED;
-- SET @Id = (SELECT customer_no FROM INSERTED);
-- SET
@remain_cost = (SELECT Balance FROM INSERTED);
--SET @remain_flow = (SELECT
(MAX_VOLUME - USED_VOLUME) FROM INSERTED);
-- 查詢對本地復制
--SET @sql =
-- SET @type = (SELECT * FROM
OPENROWSET(‘MSDASQL‘,‘smysql‘;‘root‘;‘123456‘,‘SELECT UserType_id FROM ....
@Id‘))
-- SET @base_cost = (SELECT * FROM
OPENROWSET(‘MSDASQL‘,‘smysql‘;‘root‘;‘123456‘,‘SELECT Consumer_basecost FROM
.... @Id‘))
-- DELETE FROM
OPENROWSET(‘MSDASQL‘,‘smysql‘;‘root‘;‘123456‘,‘select * from ....= @Id
‘)
-- INSERT
openrowset(‘MSDASQL‘,‘smysql‘;‘root‘;‘123456‘,‘select * from
mysql_authon.Consumer ‘) values(@Id,@type,.....)
INSERT INTO?表名稱
VALUES(@Id,.....);
COMMIT TRANSACTION
END
實例2:insert
USE [數據庫名稱]
GO
/****** Object: Trigger [dbo].[觸發器名稱] Script Date:
05/08/2014 12:47:46 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER
ON
GO
ALTER TRIGGER [dbo].[觸發器名稱] ON [dbo].[表名稱]
FOR
INSERT
AS
DECLARE
@Id VARCHAR(16),
@remain_cost
DECIMAL(10,3),
@remain_flow DECIMAL(10,3),
@valid_time
DATETIME;
BEGIN
SET XACT_ABORT ON
-- SET NOCOUNT ON added to
prevent extra result sets from
-- interfering with SELECT statements.
BEGIN TRANSACTION
SELECT @Id = customer_no........ FROM
INSERTED;
-- insert
openrowset(‘MSDASQL‘,‘smysql‘;‘root‘;‘123456‘,‘select * from
mysql_authon.Consumer ‘) values(@Id.....)
-- 將數據插入到插入用戶臨時表
INSERT
INTO dbo.transfer_data_insert_temp2 VALUES(@Id.....);
COMMIT
TRANSACTION
-- Insert statements for trigger here
END
實例3 :delete
USE [數據庫名稱]
GO
/****** Object: Trigger [dbo].[觸發器名稱] Script Date:
05/08/2014 12:51:21 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER
ON
GO
ALTER TRIGGER [dbo].[觸發器名稱] ON [dbo].[表名稱]
FOR
DELETE
AS
DECLARE
@Id VARCHAR(16);
BEGIN
SET XACT_ABORT
ON
-- SET NOCOUNT ON added to prevent extra result sets from
--
interfering with SELECT statements.
BEGIN TRANSACTION
SELECT @Id =
customer_no FROM deleted;
-- insert
openrowset(‘MSDASQL‘,‘smysql‘;‘root‘;‘123456‘,‘select * from
mysql_authon.Consumer ‘) values(@Id,....)
-- 將數據插入到插入用戶臨時表
INSERT
INTO dbo.表名稱 VALUES(@Id);
COMMIT TRANSACTION
-- Insert statements for
trigger here
END
總結
以上是生活随笔為你收集整理的MySQL触发器写入Sqlseever_sqlserver 触发器实例的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: android图形开发工具,Androi
- 下一篇: linux cmake编译源码,linu