Home  >  Article  >  Database  >  根据表的主键字段和数据字段从其它数据库同步相同表的数据

根据表的主键字段和数据字段从其它数据库同步相同表的数据

WBOY
WBOYOriginal
2016-06-07 14:57:271269browse

根据一个表的中主键字段和数据字段从其它数据库中找到结构相同的同名表,并同步相同表的数据。 无 USE [CMS2]GODECLARE @sql NVARCHAR(MAX) SET @sql=N'MERGE [dbo].[RolePermission] targetUSING [CMS].[dbo].[RolePermission] sourceON target.['+STUFF((SE

根据一个表的中主键字段和数据字段从其它数据库中找到结构相同的同名表,并同步相同表的数据。
USE [CMS2]
GO
DECLARE @sql NVARCHAR(MAX)
  SET @sql=N'MERGE [dbo].[RolePermission] target
			USING [CMS].[dbo].[RolePermission] source
			ON target.['+STUFF(
			(SELECT N'] AND target.[' + [COLUMN_NAME] + N']=source.[' + [COLUMN_NAME] FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE WHERE SUBSTRING([CONSTRAINT_NAME],1,2)='PK' AND [TABLE_NAME] = 'RolePermission' FOR XML PATH('')),1,14,N'')+'] 
			WHEN MATCHED
			THEN UPDATE SET target.['+STUFF(
			(SELECT N'],target.[' + [COLUMN_NAME] + N']=source.[' + [COLUMN_NAME] FROM INFORMATION_SCHEMA.COLUMNS WHERE [TABLE_NAME] = 'RolePermission' FOR XML PATH('')),1,10,N'')+']
			WHEN NOT MATCHED
			THEN INSERT VALUES(['+STUFF(
			(SELECT N'],[' + [COLUMN_NAME] FROM INFORMATION_SCHEMA.COLUMNS WHERE [TABLE_NAME] = 'RolePermission' FOR XML PATH('')),1,3,N'')+N'])   
			WHEN NOT MATCHED BY SOURCE THEN   
			DELETE;'
EXEC sp_executesql @sql
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn