最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

SQLServer2005中导入或覆盖数据

来源:懂视网 责编:小采 时间:2020-11-09 16:17:05
文档

SQLServer2005中导入或覆盖数据

SQLServer2005中导入或覆盖数据:公司 A 使用 SQL Server 2005 数据库。来自贸易伙伴的客户数据每天晚上都要导入到客户表。你要确保,在导入的过程中,对于存在的客户数据进行更新、对于不存在的客户数据进行插入。 无 /*INSTEAD OF 触发器的主要优点是可以使不能更新的视图支持更新。包含多
推荐度:
导读SQLServer2005中导入或覆盖数据:公司 A 使用 SQL Server 2005 数据库。来自贸易伙伴的客户数据每天晚上都要导入到客户表。你要确保,在导入的过程中,对于存在的客户数据进行更新、对于不存在的客户数据进行插入。 无 /*INSTEAD OF 触发器的主要优点是可以使不能更新的视图支持更新。包含多

公司 A 使用 SQL Server 2005 数据库。来自贸易伙伴的客户数据每天晚上都要导入到客户表。你要确保,在导入的过程中,对于存在的客户数据进行更新、对于不存在的客户数据进行插入。 无 /*INSTEAD OF 触发器的主要优点是可以使不能更新的视图支持更新。包含多

公司 A 使用 SQL Server 2005 数据库。来自贸易伙伴的客户数据每天晚上都要导入到客户表。你要确保,在导入的过程中,对于存在的客户数据进行更新、对于不存在的客户数据进行插入。 <无> $velocityCount-->
/*
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,Name,Address,Birthdate,Comment
 FROM inserted
ELSE
-- Log attempt to insert duplicate Person row in PersonDuplicates table.
 INSERT INTO PersonDuplicates
 SELECT SSN,Name,Address,Birthdate,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, Department, 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

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

SQLServer2005中导入或覆盖数据

SQLServer2005中导入或覆盖数据:公司 A 使用 SQL Server 2005 数据库。来自贸易伙伴的客户数据每天晚上都要导入到客户表。你要确保,在导入的过程中,对于存在的客户数据进行更新、对于不存在的客户数据进行插入。 无 /*INSTEAD OF 触发器的主要优点是可以使不能更新的视图支持更新。包含多
推荐度:
标签: 使用 数据 导入
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top