有没有办法在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$]
答案 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
我知道并不是很好,但是要做好这份工作。