SQL Server 2005中导入或包围数据
发布时间:2021-01-10 03:03:55 所属栏目:编程 来源:网络整理
导读:本日PHP站长网 52php.cn把网络自互联网的代码分享给各人,仅供参考。 /*INSTEAD OF 触发器的首要利益是可以使不能更新的视图支持更新。包括多个基表的视图必需行使 INSTEAD OF 触发器来支持引用表中数据的插入、更新和删
|
以下代码由PHP站长网 52php.cn网络自互联网 此刻PHP站长网小编把它分享给各人,仅供参考 /*
INSTEAD OF 触发器的首要利益是可以使不能更新的视图支持更新。包括多个基表的视图必需行使 INSTEAD OF 触发器来支持引用表中数据的插入、更新和删除操纵。INSTEAD OF 触发器的另一个利益是使您得以编写这样的逻辑代码:可以拒绝批处理赏罚中的某些部门同时应承批处理赏罚的其余部门乐成。
INSTEAD OF 触发器可以举办以下操纵:
忽略批处理赏罚中的某些部门。
不处理赏罚批处理赏罚中的某些部门并记录有题目的行。
假如碰着错误环境则采纳备用操纵。
声名 在含有效 DELETE 或 UPDATE 操纵界说的外键的表上,不能界说 INSTEAD OF DELETE 和 INSTEAD OF UPDATE 触发器。
将此逻辑作为 INSTEAD OF 触发器的一部门举办编码,可停止全部会见数据的应用措施必需从头执行该逻辑。
在下列 Transact-SQL 语句序列中,INSTEAD OF 触发器更新视图中的两个基表。其它,表现两种处理赏罚错误的要领:
忽略对 Person 表的一再插入,而且插入的信息将记录在 PersonDuplicates 表中。
将对 EmployeeTable 表的一再插入转变为 UPDATE 语句,该语句将当前信息检索至 EmployeeTable,而不会发生一再键加害。 Transact-SQL 语句建设两个基表、一个视图、一个记录错误表和视图上的 INSTEAD OF 触发器。下面的这些表将小我私人数据和营业数据分隔而且是视图的基表:
*/
CREATE TABLE Person
(
SSN char(11) PRIMARY KEY,Name nvarchar(100),Address nvarchar(100),Birthdate datetime
)
CREATE TABLE EmployeeTable
(
EmployeeID int PRIMARY KEY,SSN char(11) UNIQUE,Department nvarchar(10),Salary money,CONSTRAINT FKEmpPer FOREIGN KEY (SSN)
REFERENCES Person (SSN)
)
--下面的视图行使某小我私人的两个表中的全部相干数据成立报表:
CREATE VIEW Employee AS
SELECT P.SSN as SSN,Name,Address,Birthdate,EmployeeID,Department,Salary
FROM Person P,EmployeeTable E
WHERE P.SSN = E.SSN
--可记录对插入具有一再的社会安详号的行的实行。PersonDuplicates 表记录插入的值、实行插入操纵的用户的用户名和插入的时刻:
CREATE TABLE PersonDuplicates
(
SSN char(11),Name nvarchar(100),Address nvarchar(100),Birthdate datetime,InsertSNAME nchar(100),WhenInserted datetime
)
--INSTEAD OF 触发器在单独视图的多个基表中插入行。将对插入具有一再社会安详号的行的实行记录在 PersonDuplicates 表中。将 EmployeeTable 中的一再行变动为更新语句。
CREATE TRIGGER IO_Trig_INS_Employee ON Employee
INSTEAD OF INSERT
AS
BEGIN
SET NOCOUNT ON
-- Check for duplicate Person. If no duplicate,do an insert.
IF (NOT EXISTS (SELECT P.SSN
FROM Person P,inserted I
WHERE P.SSN = I.SSN))
INSERT INTO Person
SELECT SSN,Comment
FROM inserted
ELSE
-- Log attempt to insert duplicate Person row in PersonDuplicates table.
INSERT INTO PersonDuplicates
SELECT SSN,SUSER_SNAME(),GETDATE()
FROM inserted
-- Check for duplicate Employee. If no duplicate,do an insert.
IF (NOT EXISTS (SELECT E.SSN
FROM EmployeeTable E,inserted
WHERE E.SSN = inserted.SSN))
INSERT INTO EmployeeTable
SELECT EmployeeID,SSN,Salary,Comment
FROM inserted
ELSE
--If duplicate,change to UPDATE so that there will not
--be a duplicate key violation error.
UPDATE EmployeeTable
SET EmployeeID = I.EmployeeID,Department = I.Department,Salary = I.Salary,Comment = I.Comment
FROM EmployeeTable E,inserted I
WHERE E.SSN = I.SSN
END
以上内容由PHP站长网【52php.cn】网络清算供各人参考研究 假如以上内容对您有辅佐,接待保藏、点赞、保举、分享。 (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |


