在insert语句中捕获错误时的fieldname

时间:2015-09-25 14:27:16

标签: sql sql-server tsql

有没有办法在SQL 2014中获取插件上发生错误的字段名称。我插入了30多个字段,并且浪费了数小时试图找出错误发生的位置。看起来像一个简单的调试功能,但我得到的错误是

  

Msg 8114,Level 16,State 5,Line 2

     

将数据类型nvarchar转换为数字时出错。

我已经通过插入表中的每个数字列,并尝试将相应的数据转换为正确的数据类型,但无法找到问题。

INSERT INTO [dbo].[Employee]
       (
        [EmployeeID]
       ,[FirstName]
       ,[LastName]
       ,[ManagerID]
       ,[CurrencyCode]
       ,[CountryCode]
       ,[JobTitle]
       ,[Grade]
       ,[IsPlanningEligible] -- BIT
       ,[HireDate]
       ,[LastSalaryReviewDate]
       ,[AnnualSalaryAmt] -- Money
       ,[AnnualSalaryRangeMinAmt] --'NUMERIC'
       ,[AnnualSalaryRangeMidAmt] --'NUMERIC'
       ,[AnnualSalaryRangeMaxAmt] --'NUMERIC'
       ,[PositionInSalaryRange]
       ,[MeritIsEligible] -- BIT
       ,[MeritIsLocked] -- BIT
       ,[MeritBudgetKey]
       ,[LegacyCompany] 
       ,[FTEPct] --'NUMERIC'    
       ,[PreviousYearPerformance] 
       ,[LastIncreasePct] --'NUMERIC'
       ,[LastIncreaseReason] 
       ,[Location]
       ,[CostCenter]  
       ,[ManagerName]
       ,[MeritEffectiveDateByCountry]
       ,[HRBPPersonnelNumber]
       ,[HRBPName]
       ,[HREmployee]  
       ,[LocalPersonnelNumber]
       ,[EmailAddress]
       ,[OrgLevel1]
       ,[OrgLevel2]
       ,[OrgLevel3]
       ,[OrgLevel4]
       ,[OrgLevel5]
       ,[OrgLevel6]         
     )


 /*** IGT STAGING SELECT ***/

  SELECT  LTRIM(Str([Personnel Number], 25, 0))
  ,[Preferred First Name]
  ,[Last Name]
  ,CAST([Manager Personnel Number] AS NVARCHAR(50))
  ,[Currency]
  ,[Country] 
  ,[Job Title]
  ,[Grade]
  ,CAST([Planning Eligible] AS BIT)
  ,[Date of Hire]
  ,[Last Increase Date]
  ,[Annual Base Salary_(as of mm/dd/yyyy) ]
  ,[Minimum of Range]
  ,[Midpoint of Range]
  ,[Maximum of Range]
  ,CAST([Position in Range] AS NVARCHAR(50))
  ,[Merit Eligible ]
  ,[MeritLocked]
  ,[Merit Budget %]
    /*IGT Custom Fields */
  ,[Legacy Company] 
  ,[FTE %]  
  ,[Previous Year's Performance] 
  ,[Last Increase (%)]
  ,[Last Increase Reason]
  ,[Location]
  , CAST([Cost Center] AS NVARCHAR(50))
  ,[Manager Name]
  ,[Merit Effective Date (by Country)]
  ,CAST([HRBP Personnel Number] AS NVARCHAR(50))
  ,[HRBP Name]
  ,[HR Employee (yes/no)]         
  ,[Local Personnel Number]
  ,[Email Address]
  ,[Org Level 1]
  ,[Org Level 2]
  ,[Org Level 3]
  ,[Org Level 4]
  ,[Org Level 5]
  ,[Org Level 6] 

   FROM [IGT_Compensation].[dbo].[IGT_Staging$]

1 个答案:

答案 0 :(得分:0)

解决问题的最佳方法是使用ISNumeric函数

检查字段
SELECT ID, field1, field2 .., fieldN
FROM yourTable
WHERE 
     ISNUMERIC(field1) = 0
OR   ISNUMERIC(field2) = 0
...
OR   ISNUMERIC(fieldN) = 0

如果您使用INSERT进行CASE尝试并将其更改为默认值。

INSERT INTO YourTable
Values (
      CASE 
          WHEN ISNUMERIC(field1) = 0 THEN -999
          ELSE CAST (field1 as numeric) 
      END as field1,
      CASE 
          WHEN ISNUMERIC(field2) = 0 THEN -999
          ELSE CAST (field2 as numeric) 
      END as field2,
      ...

然后搜索YourTable -999

我知道并不是很好,但是要做好这份工作。