2016-09-23 79 views
0

我试图创建一个脚本来连接各种值,最终它创建一个插入脚本,我已经做了一个。创建插入脚本SQL

INSERT INTO #SCRPTS 
SELECT getdate(), 
    'INSERT WKF_TpProcesso VALUES (''' + Des_TpProcesso + ''',' + cast(Cod_Func as Varchar(8)) + ',getdate() ,null ,1 ,' + CASE WHEN Id_Sistema IS NULL THEN 'Null' ELSE CAST(Id_Sistema as Varchar(6)) END 
    +',0,1,0,'+ CASE WHEN Des_CodigoTpProcesso IS NULL THEN 'Null' ELSE '''' + Des_CodigoTpProcesso END +''''+ ','+CAST(Flg_ProxProcesso as Varchar(1))''')' 
FROM WKF_TpProcesso 
WHERE Des_CodigoTpProcesso = @Des_CodigoTpProcesso 

结果是这样的:

INSERT WKF_TpProcesso VALUES ('Processo Teste',41815,getdate() ,null ,1 ,169,0,1,0, 'PcTestPlus',1) 

我在做另一个但无法弄清楚,为什么不工作。

WHILE (exists (select Id_EtapaCampoGen from WKF_EtapaCampoGen Where Id_Etapa = @Id_Etapa)) 

    INSERT INTO #SCRPTS 
    SELECT getdate(), 
     'INSERT WKF_EtapaCampoGen VALUES 
     (@Id_Etapa' +  
     ','+ ''''+ Des_Label + '''' + 
     ','+ ''''+ Vl_Identificador + '''' + 
     ','+ cast(Flg_Obrigatorio as Varchar(2)) + 
     ',getdate(),'+ 
     ',' + CASE WHEN DT_Alteracao IS NULL OR DT_Alteracao = '' THEN 'NULL' ELSE '''' + 
     ',' + cast(FLG_Situacao as Varchar(2))+ 
     ',' + '''' + Tipo + '''' + 
     ',' + '''' + Query + '''' +')' 

     FROM WKF_EtapaCampoGen 

我有错误“不正确的sintax附近FROM”,但我不能看到有什么不对,有人知道吗? 有趣的是,例如在这个列Des_Label是脚本数据库找到它来自哪里的参考,但如果我从它的声明中有错误它可以找到?


这是一个END失踪的情况下,当stament结束脚本返回这个。

INSERT WKF_EtapaCampoGen VALUES 
     (@Id_Etapa,'Areas','CampoComplementar1',0,getdate(),NULL,1,'Lista','select Des_area as Texto, Des_area as valor from wkf_area') 
+1

你有一个'+'在表达式的结束......它不仅是从附近的前右它。不知道它如何可能比这更接近。 – Hogan

+0

最后一个+确实是错的,但并没有从'FROM'中删除错误。 –

+0

最后我错过了一个''',我编辑了这些变化。 –

回答

1

的情况下表达需要一个END

CASE WHEN DT_Alteracao IS NULL OR DT_Alteracao = '' THEN 'NULL' ELSE '''''' END 
+0

谢谢,它工作正常。 –