Dynamische SQL Server Frage
-
06-09-2019 - |
Frage
Ich mag dymamic SQL-Code erstellen, um automatisch eine Tabelle Replikation zu erstellen.
Ich bin fest, wie der folgende Code dynamisch zu machen, so dass es möglich ist, in SQL-Variablen zu übergeben und sie im Code verwenden. Ich helfe mir zur Zeit mit Suche und die 'TODO:'
Teile ersetzt werden, die nicht sehr schön ist ... Hier ist der Code:
DECLARE @sql VARCHAR(MAX)
SET @sql = ''
SELECT
@sql = @sql +
'exec sp_addarticle @publication = ''TODO:TREP_PUBLICATION_NAME'',@article = N''' +
name +
''', @source_owner = N''dbo'', @source_object = N''' +
name +
''', @type = N''logbased'', @description = N'''', @creation_script = N'''', @pre_creation_cmd = N''delete'', @schema_option = 0x0000000000000000, @identityrangemanagementoption = N''none'', @destination_table = N''' +
name +
''', @destination_owner = N''dbo'', @status = 8, @vertical_partition = N''false'', @ins_cmd = N''SQL'', @del_cmd = N''SQL'', @upd_cmd = N''SQL'''
FROM
TODO:PUBLICATION_DB.sys.tables
WHERE
type = 'U'
AND name IN (
SELECT
name
FROM
OPENROWSET('SQLOLEDB', 'TODO:SUBSCRIBER_SERVER';
'TODO:SUBSCRIBER_LOGIN';
'TODO:SUBSCRIBER_PASSWORD', 'select * from TODO:SUBSCRIBER_DB.sys.tables where type=''U''')
)
AND name IN (
SELECT
TABLE_NAME
FROM
TODO:PUBLICATION_DB.INFORMATION_SCHEMA.TABLE_CONSTRAINTS
WHERE
TODO:TABLE_NAME_FILTER
)
EXEC(@Sql)
Ein Problem ist, dass ich dynamischen SQL innerhalb eines dynamischen SQL-Blockes muß. Wenn jemand mir helfen könnte diesen Code mit Variablen zu konvertieren würde ich wirklich sehr lieb!
Danke Daniel
Lösung
Dynamische SQL möglicherweise nicht die Antwort sein - aber das bedeutet nicht, dass Sie es nicht einfacher machen zu automatisieren und ‚Parameter-ize‘.
Mit anderen Worten, ich schaffte es einmal eine riesige Replikationstopologie, wo ich musste oft Abonnenten abzureißen, und auch (gelegentlich) neu Publikationen, und so weiter. Anstatt Ausmisten mit dem Versuch, T-SQL zu generieren, die dynamisch Dinge abgefragt und tat alles auf einen Schlag-swoop, erstelle ich eine Reihe von T-SQL-Vorlagen (.tql Dateien), die dann könnte ich mit ein paar Parameter zu füllen, verwenden und dann drehen verlieren.
Und wenn Sie mit Vorlagen nicht vertraut sind, nur dieses Video Check-out -, die Sie schnell bis zu Geschwindigkeit erhalten wird:
http://www.sqlservervideos.com/video/using-sql -Server-Vorlagen
Und hier ist ein Beispiel für die Art von Vorlage Ich war mit Artikel hinzufügen - wie Sie schießen für:
/* Add Article */
USE [<database,sysname,--Default>]
GO
EXEC sp_addarticle
@publication = N'<publicationName,sysname,--Default>',
@article = N'<article_1,sysname,--Default>',
@source_owner = N'dbo',
@source_object = N'<article_1,sysname,--Default>',
@destination_table = N'<article_1,sysname,--Default>',
@type = N'logbased',
@creation_script = null,
@description = null,
@pre_creation_cmd = N'drop',
@schema_option = <bitmask_1,binary(8),0x000000000000CCD3>,
@status = 16,
@vertical_partition = N'false',
@ins_cmd = N'CALL sp_MSins_<article_1,sysname,--Default>',
@del_cmd = N'CALL sp_MSdel_<article_1,sysname,--Default>',
@upd_cmd = N'MCALL sp_MSupd_<article_1,sysname,--Default>',
@filter = null,
@sync_object = null,
@auto_identity_range = N'false'
GO
EXEC sp_addarticle
@publication = N'<publicationName,sysname,--Default>',
@article = N'<article_2,sysname,--Default>',
@source_owner = N'dbo',
@source_object = N'<article_2,sysname,--Default>',
@destination_table = N'<article_2,sysname,--Default>',
@type = N'logbased',
@creation_script = null,
@description = null,
@pre_creation_cmd = N'drop',
@schema_option = <bitmask_2,binary(8),0x000000000000CCD3>,
@status = 16,
@vertical_partition = N'false',
@ins_cmd = N'CALL sp_MSins_<article_2,sysname,--Default>',
@del_cmd = N'CALL sp_MSdel_<article_2,sysname,--Default>',
@upd_cmd = N'MCALL sp_MSupd_<article_2,sysname,--Default>',
@filter = null,
@sync_object = null,
@auto_identity_range = N'false'
GO
EXEC sp_addarticle
@publication = N'<publicationName,sysname,--Default>',
@article = N'<article_3,sysname,--Default>',
@source_owner = N'dbo',
@source_object = N'<article_3,sysname,--Default>',
@destination_table = N'<article_3,sysname,--Default>',
@type = N'logbased',
@creation_script = null,
@description = null,
@pre_creation_cmd = N'drop',
@schema_option = <bitmask_3,binary(8),0x000000000000CCD3>,
@status = 16,
@vertical_partition = N'false',
@ins_cmd = N'CALL sp_MSins_<article_3,sysname,--Default>',
@del_cmd = N'CALL sp_MSdel_<article_3,sysname,--Default>',
@upd_cmd = N'MCALL sp_MSupd_<article_3,sysname,--Default>',
@filter = null,
@sync_object = null,
@auto_identity_range = N'false'
GO
EXEC sp_addarticle
@publication = N'<publicationName,sysname,--Default>',
@article = N'<article_4,sysname,--Default>',
@source_owner = N'dbo',
@source_object = N'<article_4,sysname,--Default>',
@destination_table = N'<article_4,sysname,--Default>',
@type = N'logbased',
@creation_script = null,
@description = null,
@pre_creation_cmd = N'drop',
@schema_option = <bitmask_4,binary(8),0x000000000000CCD3>,
@status = 16,
@vertical_partition = N'false',
@ins_cmd = N'CALL sp_MSins_<article_4,sysname,--Default>',
@del_cmd = N'CALL sp_MSdel_<article_4,sysname,--Default>',
@upd_cmd = N'MCALL sp_MSupd_<article_4,sysname,--Default>',
@filter = null,
@sync_object = null,
@auto_identity_range = N'false'
GO
Und in einigen Fällen ... Ich habe auch diese Vorlagen, die wiederum eine verschachtelte / dynamische SQL hatten. Aber beide verwenden, fand ich, dass ich in der Lage war sehr leicht, einige der mehr redundanten Aufgaben zu zähmen notwendig, ohne zu verkomplizieren Dinge.