Comment créer des tables dynamiquement dans des procédures stockées en T-SQL
Création d'une variable de table en tant que table temporaire, comme indiqué dans le exemple, est incorrect. Pour créer une table temporaire, utilisez la syntaxe suivante :
CREATE TABLE #customer ( Name varchar(32) not null )
Pour déclarer une variable de table, utilisez cette syntaxe :
DECLARE @Customer TABLE ( Name varchar(32) not null )
Dynamic SQL propose une méthode alternative pour créer des tables dans des fichiers stockés. procédures. Vous pouvez construire une instruction SQL sous forme de chaîne et l'exécuter :
CREATE PROCEDURE sproc_BuildTable @TableName NVARCHAR(128) ,@Column1Name NVARCHAR(32) ,@Column1DataType NVARCHAR(32) ,@Column1Nullable NVARCHAR(32) AS DECLARE @SQLString NVARCHAR(MAX) SET @SQString = 'CREATE TABLE '+@TableName + '( '+@Column1Name+' '+@Column1DataType +' '+@Column1Nullable +') ON PRIMARY ' EXEC (@SQLString) GO
Cette procédure stockée peut être exécutée comme suit :
sproc_BuildTable 'Customers','CustomerName','VARCHAR(32)','NOT NULL'
Cependant, la création dynamique de tables dans des procédures stockées est généralement déconseillé en raison de :
Si vous avez besoin que les tables soient créées dynamiquement, envisagez d'explorer d'autres solutions telles que les magasins mappent vers les tableaux de produits existants avec des prix définis.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!