VS2010 Database project deploy - “SqlDeployTask” task failed unexpectedly, NullReferenceException

℡╲_俬逩灬. 提交于 2019-12-07 13:17:28

Tom, I've documented a workaround (and a very easy one at that) here: http://sqlblog.com/blogs/jamie_thomson/archive/2011/11/21/workaround-for-datadude-deployment-bug.aspx

I have encountered similar NullReference exception attached below when had the following scenario:

  1. I've edited the definition of partition scheme PS1 of SQL Database project and all tables which were using it (T1, T2, T3)
  2. However, in my database, I had an old table not defined in the code (T_old) but still not deleted from the database (it was not used anymore, but dacpac doesn't remove stuff for you, only changes or adds). This old table was using the same partition scheme, but dacpac didn't have any reference to that old table definion meaning it was not able to backup table T_old to change PS1

You can have similar issues when referencing objects that changed by old objects that are not defined in code anymore.

To solve that, check the old dependencies of the object and delete them. Try to change things only in code and not mix it with ad-hock changes in database.

Hope that will help, since error message doesn't give a lot of explanation.

Unhandled Exception: System.NullReferenceException: Object reference not set to an instance of an object.
    at Microsoft.Data.Tools.Schema.Sql.Deployment.SqlDeploymentPlanGenerator.DeploymentScriptDomGenerator.UnbindTableDatamotion(SqlTable sourceTable, SqlTable targetTable, Boolean unbindPartitionScheme, HashSet`1 unboundColumns)
    at Microsoft.Data.Tools.Schema.Sql.Deployment.SqlDeploymentPlanGenerator.DeploymentScriptDomGenerator.GenerateUnbindTableSteps(SqlTable sourceTable, SqlTable targetTable)
    at Microsoft.Data.Tools.Schema.Sql.Deployment.SqlDeploymentPlanGenerator.DeploymentScriptDomGenerator.GenerateSteps(Int32 operation, IModelElement element)
...

I've been able to reproduce this error with a test database project containing a single in-line function as follows:

CREATE FUNCTION [dbo].[Function1]
()
RETURNS TABLE
AS
    RETURN (
        WITH cte AS (
            SELECT 1 AS [c1]
            FROM [$(Database3)].[dbo].[Table1]
        )
        SELECT 1 AS [c1]
        FROM cte
    )

$(Database3) is a database variable that references another database project .dbschema file. This dbschema file contains a single table - [Table1].

It seems that you need an inline function with a CTE that contains a reference to another database using a database variable. Additionally, the function must already exist on the target database.

You may get the following error under some circumstances (e.g. the inline function doesn't use a CTE):

------ Deploy started: Project: Database2, Configuration: Debug Any CPU ------
Database2.dbschema(0,0): Warning TSD00560: If this deployment is executed, changes to [dbo].[Function2] might introduce run-time errors in [dbo].[Procedure1].
    Deployment script generated to:
C:\temp\Database2\sql\debug\Database2.sql

    Altering [dbo].[Function2]...
C:\temp\Database2\sql\debug\Database2.sql(74,0): Error SQL01268: .Net SqlClient Data Provider: Msg 208, Level 16, State 1, Procedure Function2, Line 9 Invalid object name 'Database3.dbo.Table1'.
    An error occurred while the batch was being executed.
   Done executing task "SqlDeployTask" -- FAILED.
  Done building target "DspDeploy" in project "Database2.dbproj" -- FAILED.
 Done executing task "CallTarget" -- FAILED.
Done building target "DBDeploy" in project "Database2.dbproj" -- FAILED.
Done building project "Database2.dbproj" -- FAILED.

Build FAILED.

So the only workaround seems to be to drop the function in the target before the deployment.

I'll raise a Microsoft Connect issue.

UPDATE

I've created a Connect issue - https://connect.microsoft.com/VisualStudio/feedback/details/693158/vs2010-database-project-deploy-sqldeploytask-task-failed-unexpectedly-nullreferenceexception

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!