Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/22.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql server 15,State 1,Procedure lakerrowhead_schedule_python,第111行[批处理开始行0]关键字“AS”附近的语法不正确。是的,我觉得很奇怪,我不得不在存储过程的末尾删除临时表。我甚至删除了SP,并尝试执行创建而不是更_Sql Server_Tsql_Stored Procedures_Cursor_Temp Tables - Fatal编程技术网

Sql server 15,State 1,Procedure lakerrowhead_schedule_python,第111行[批处理开始行0]关键字“AS”附近的语法不正确。是的,我觉得很奇怪,我不得不在存储过程的末尾删除临时表。我甚至删除了SP,并尝试执行创建而不是更

Sql server 15,State 1,Procedure lakerrowhead_schedule_python,第111行[批处理开始行0]关键字“AS”附近的语法不正确。是的,我觉得很奇怪,我不得不在存储过程的末尾删除临时表。我甚至删除了SP,并尝试执行创建而不是更,sql-server,tsql,stored-procedures,cursor,temp-tables,Sql Server,Tsql,Stored Procedures,Cursor,Temp Tables,15,State 1,Procedure lakerrowhead_schedule_python,第111行[批处理开始行0]关键字“AS”附近的语法不正确。是的,我觉得很奇怪,我不得不在存储过程的末尾删除临时表。我甚至删除了SP,并尝试执行创建而不是更改,但仍然出现错误。哈哈,这太令人沮丧了。我可能需要走另一条路线,但从我的web应用程序中输入3个ID并运行原始的联合查询。您的检查语句似乎正在查看与tempdb不同的数据库,还是我遗漏了什么?@AnthonyHancock我尝试了tempdb


15,State 1,Procedure lakerrowhead_schedule_python,第111行[批处理开始行0]关键字“AS”附近的语法不正确。是的,我觉得很奇怪,我不得不在存储过程的末尾删除临时表。我甚至删除了SP,并尝试执行创建而不是更改,但仍然出现错误。哈哈,这太令人沮丧了。我可能需要走另一条路线,但从我的web应用程序中输入3个ID并运行原始的联合查询。您的检查语句似乎正在查看与tempdb不同的数据库,还是我遗漏了什么?@AnthonyHancock我尝试了tempdb,但也检查了此过程进入的数据库(IPAM)以防服务器出于某种奇怪的原因把它放在那里。它被卡在SQL lala land的内存中的某个地方,因为我在任何地方都找不到它。您使用的是什么版本的SQL Server?我不记得具体情况,但我也曾遇到过类似的情况。我只是在没有if语句的情况下独自运行drop表,然后重新运行所有内容,它通常都会工作。也许可以试试。@AnthonyHancock SQL Server 2017,哈哈,我也尝试过在没有任何检查或任何东西的情况下删除表,但仍然没有成功。
IF OBJECT_ID('IPAM..#tempschedule') IS NOT NULL
BEGIN
    PRINT '#temp exists!'
END
ELSE
BEGIN
    PRINT '#temp does not exist!'
END
ALTER PROCEDURE lakearrowhead_schedule_python
AS
    IF OBJECT_ID('tempdb..#tempschedule') IS NOT NULL
    BEGIN
        DROP TABLE #tempschedule;
    END;

    CREATE TABLE #tempschedule
    (
        ProgramID INT,
        ItemID INT,
        Day SMALLINT,
        [Date] DATE,
        [Begin TIME] VARCHAR(15),
        [End TIME] VARCHAR(15),
        TIMESLOT NVARCHAR(11),
        SLOTTYPE INT,
        SlotTypeDescription NVARCHAR(64),
        SLOTINFO INT,
        SlotInfoDescription NVARCHAR(500),
        TalkID INT,
        Talk NVARCHAR(50),
        FIRSTNAME NVARCHAR(20),
        LASTNAME NVARCHAR(50),
        INSTITUTION NVARCHAR(150),
        AUTHORLINE NVARCHAR(384),
        TITLE NVARCHAR(256),
        Abstract VARCHAR(1),
        [LOCATION] INT,
        ADDENDUM TEXT,
        EventName NVARCHAR(256)
    );

    DECLARE @pid INT;

    DECLARE PROGRAM_cursor CURSOR FOR
        SELECT TOP 3 WebEvents.EventID
        FROM WebEvents
        INNER JOIN dbo.WebPrograms ON dbo.WebEvents.EventID = dbo.WebPrograms.ProgramID
        WHERE EventLocation = 1004
          AND (eventstartdate >= GETDATE())
        ORDER BY 
            eventstartdate, ProgramCode;

    OPEN PROGRAM_cursor;

    FETCH NEXT FROM PROGRAM_cursor INTO @pid;

    WHILE @@FETCH_STATUS = 0
    BEGIN
        SELECT *
        INTO #tempschedule
        FROM 
            (SELECT 
                 WS.ProgramID ,
                 WS.ItemID ,
                 WS.Day ,
                 CASE DATEPART(WEEKDAY, DATEADD(DAY, WS.Day - 1, WE.eventstartdate))
                     WHEN 1 THEN 'Sun'
                     WHEN 2 THEN 'Mon'
                     WHEN 3 THEN 'Tue'
                     WHEN 4 THEN 'Wed'
                     WHEN 5 THEN 'Thu'
                     WHEN 6 THEN 'Fri'
                     WHEN 7 THEN 'Sat'
                     ELSE 'N/A'
                 END + ' ' + CONVERT(CHAR(12), DATEADD(DAY, WS.Day - 1, WE.eventstartdate), 101) AS Date,
                 CONVERT(VARCHAR(15), CONVERT(TIME, SUBSTRING(WS.TimeSlot, 0, 6)), 100) AS 'Begin TIME',
                 CONVERT(VARCHAR(15), CONVERT(TIME, SUBSTRING(WS.TimeSlot, 7, 6)), 100) AS 'End TIME',
                 WS.TimeSlot,
                 WS.SlotType,
                 WSSTC.Description AS SlotTypeDescription,
                 WS.SlotInfo,
                 WSSIC.Description AS SlotInfoDescription,
                 ISNULL(WSI.TalkID, 0) AS TalkID,
                 LEFT(WPI.FirstName, 10) + ' '
                     + LEFT(WPI.LastName, 10) + ' ('
                     + LEFT(WEA.institution, 10) + ')' + ' - '
                     + LEFT(WSI.Title, 10) + '...'
                     + RIGHT(WSI.Title, 10) AS Talk,
                 WPI.FirstName,
                 WPI.LastName,
                 WEA.institution,
                 WSI.AuthorLine,
                 WSI.Title,
                 LEFT(WSI.Abstract, 1) AS Abstract,
                 WS.Location,
                 WS.Addendum,
                 WE.EventName
             FROM   
                 dbo.WebSpeakerInfo WSI
             INNER JOIN 
                 dbo.WebPersonalInfo WPI ON WSI.UserID = WPI.UserID
             INNER JOIN 
                 dbo.webeventaffiliation WEA ON WPI.UserID = WEA.userid
                                             AND WEA.eventid = @pid
             RIGHT OUTER JOIN 
                 dbo.WebScheduleSlotTypeCodes WSSTC 
             RIGHT OUTER JOIN 
                 dbo.WebSchedules WS ON WSSTC.SlotType = WS.SlotType 
                 ON WSI.TalkID = WS.TalkID
             LEFT OUTER JOIN 
                 dbo.WebScheduleSlotInfoCodes WSSIC ON WS.SlotInfo = WSSIC.SlotInfo
             INNER JOIN 
                 dbo.WebEvents WE ON WE.EventID = @pid
             WHERE  
                 WS.ProgramID = @pid
                 AND WS.SlotType <> 6 ) AS x
            ORDER BY 
                 Day, TimeSlot;

        FETCH NEXT FROM PROGRAM_cursor INTO @pid;
    END;

    CLOSE PROGRAM_cursor;
    DEALLOCATE PROGRAM_cursor;

    SELECT *
    FROM #tempschedule;

    DROP TABLE #tempschedule;
ALTER PROCEDURE lakearrowhead_schedule_python
AS
    IF OBJECT_ID('tempdb..#tempschedule') IS NOT NULL
        BEGIN
            DROP TABLE #tempschedule;
        END;