我有这个查询,并且在')'(CREATE TABLE结束)和'END'附近得到错误的语法错误。
现在,如果我删除BEGIN和END行,这样可以正常工作,但我不能完全确定它是什么原因。
注意:这不是最终产品,因为在此之后还有更多产品会在此之后发生。这只是一个更大的项目的一部分,但是这些部分是相当独立的,除了[ARCSCON]表的存在之外,此查询中的任何内容都不依赖于任何其他部分。
谁能告诉我我做错了什么?
IF EXISTS( SELECT * FROM sys.objects
WHERE OBJECT_ID = OBJECT_ID(N'[dbo].[ARCSCON]'))
BEGIN
CREATE TABLE [tempSAItems](
[Id] int identity(44444,1),
[Name] nvarchar(55),
[Type] nvarchar(50) DEFAULT 'Service Agreement',
[Inactive] bit DEFAULT '0',
[Purchased] bit DEFAULT '0',
[MSDS] bit DEFAULT '0',
[IncomeAccountID] int DEFAULT '7',
[LaborCoverd] bit DEFAULT '0',
[PartsCoverd] bit DEFAULT '0',
[LifeTime] bit DEFAULT '0',
[TravelCoverd] bit DEFAULT '0',
[NumVisits] int, --[DURATION]
[bLaborItem] bit DEFAULT '0',
[bDirectCost] bit DEFAULT '0',
[bAddToSales] bit DEFAULT '0',
[sCostingMethod] nvarchar(50) DEFAULT 'Average Cost')
GO
INSERT INTO [tempSAItems]([Name])
SELECT DISTINCT [SCHEDTYPE]
FROM [ARCSCON]
GO
END
答案 0 :(得分:1)
由于@LittleBoobyTables评论了中间写的Go
的Rid。
IF EXISTS( SELECT * FROM sys.objects
WHERE OBJECT_ID = OBJECT_ID(N'[dbo].[ARCSCON]'))
BEGIN
CREATE TABLE [tempSAItems](
[Id] int identity(44444,1),
[Name] nvarchar(55),
[Type] nvarchar(50) DEFAULT 'Service Agreement',
[Inactive] bit DEFAULT '0',
[Purchased] bit DEFAULT '0',
[MSDS] bit DEFAULT '0',
[IncomeAccountID] int DEFAULT '7',
[LaborCoverd] bit DEFAULT '0',
[PartsCoverd] bit DEFAULT '0',
[LifeTime] bit DEFAULT '0',
[TravelCoverd] bit DEFAULT '0',
[NumVisits] int, --[DURATION]
[bLaborItem] bit DEFAULT '0',
[bDirectCost] bit DEFAULT '0',
[bAddToSales] bit DEFAULT '0',
[sCostingMethod] nvarchar(50) DEFAULT 'Average Cost')
--GO
^Here
INSERT INTO [tempSAItems]([Name])
SELECT DISTINCT [SCHEDTYPE]
FROM [ARCSCON]
GO
END