Scripter25
asked on
Stored Procedure Microsoft OLE DB Provider for ODBC Drivers error '80040e14' Incorrect syntax
Please tell me what is wrong with this stored procedure
Microsoft OLE DB Provider for ODBC Drivers error '80040e14'
[Microsoft][ODBC SQL Server Driver][SQL Server]Line 9: Incorrect syntax near 'Class_Events'.
If I do the same exact query in query analyzer it works I have no idea what is going wrong
CREATE PROCEDURE usp_Students_Report_Enroll
@class_number varchar(32),
@dept_id varchar(32)=0,
@sortby varchar(128) = 'last_name, first_name',
@oby varchar(32) = 'ASC'
AS
DECLARE @s varchar(1024)
SET @s = ' SELECT dbo.department.department_ name,dbo.b ureau.bure au_name, dbo.Instructors.Instructor _name, dbo.Classes.deleted_class, dbo.Course_Definition.mand atory, dbo.Employee.lastname, dbo.Employee.firstname, dbo.Classes.Class_Number,
(SELECT TOP 1 Class_events.Event_Type
FROM dbo.Class_Events
WHERE dbo.Class_Events.Class_Num ber = dbo.Classes.Class_Number
ORDER BY CASE WHEN dbo.Class_Events.event_typ e = ''Passed Course'' THEN 1 WHEN dbo.Class_Events.event_typ e = ''Past Test'' THEN 2 WHEN
dbo.Class_Events.event_typ e = ''Attempted Test'' THEN 3 ELSE 4 END DESC) AS Event_Type,
CASE WHEN (dbo.Classes.ongoing =0) THEN Classes.Class_Start_Date WHEN dbo.classes.ongoing =1 THEN
(SELECT TOP 1 Class_events.Event_Date
FROM dbo.Class_Events
WHERE dbo.Class_Events.Class_Num ber = dbo.Classes.Class_Number
ORDER BY CASE WHEN dbo.Class_Events.event_typ e = ''Passed Course'' THEN 1 WHEN dbo.Class_Events.event_typ e = ''Past Test'' THEN 2 WHEN
dbo.Class_Events.event_typ e = ''Attempted Test'' THEN 3 ELSE 4 END) END AS completion_date,
CASE WHEN dbo.Classes.Status =''Classroom'' THEN ''Web-Assisted'' WHEN dbo.classes.status = ''OPEN'' THEN ''Web-Based'' ELSE ''All Other'' END AS Type,
CASE WHEN
dbo.Classes.ongoing =0 THEN Classes.Class_Start_Date WHEN dbo.Classes.ongoing=1 THEN Activity.Start_Date END AS Start_date,
dbo.Classes.teacher, dbo.Classes.Class_Start_Da te, dbo.Classes.department_id, dbo.Classes.teacher AS Expr1, dbo.Students.Student_Numbe r,
dbo.Students.Bureau_ID, dbo.Course_Definition.Cour se_Descrip tion, dbo.Course_Definition.Stan dard_Hours , dbo.Classes.Course_Number
FROM dbo.Students INNER JOIN
dbo.Activity ON dbo.Students.Student_Numbe r = dbo.Activity.Student_Numbe r INNER JOIN
dbo.bureau ON dbo.Students.Bureau_ID=dbo .bureau.bu reau_id INNER JOIN
dbo.Employee ON dbo.Students.employee_id = dbo.Employee.employee_ID INNER JOIN
dbo.Classes ON dbo.Activity.Class_Number = dbo.Classes.Class_Number INNER JOIN
dbo.Course_Definition ON dbo.Course_Definition.Cour se_Def_Num ber = dbo.Classes.Course_Number INNER JOIN
dbo.department ON dbo.Classes.department_id = dbo.department.department_ id INNER JOIN
dbo.Instructors ON dbo.Classes.Instructor_Num ber=dbo.In structors. Instructor _number
WHERE dbo.classes.Class_Number=' + @class_number
SET @s = @s +' order by ' + @sortby
if @oby <> ''
SET @s = @s + ' ' + @oby
EXEC(@s)
GO
Microsoft OLE DB Provider for ODBC Drivers error '80040e14'
[Microsoft][ODBC SQL Server Driver][SQL Server]Line 9: Incorrect syntax near 'Class_Events'.
If I do the same exact query in query analyzer it works I have no idea what is going wrong
CREATE PROCEDURE usp_Students_Report_Enroll
@class_number varchar(32),
@dept_id varchar(32)=0,
@sortby varchar(128) = 'last_name, first_name',
@oby varchar(32) = 'ASC'
AS
DECLARE @s varchar(1024)
SET @s = ' SELECT dbo.department.department_
(SELECT TOP 1 Class_events.Event_Type
FROM dbo.Class_Events
WHERE dbo.Class_Events.Class_Num
ORDER BY CASE WHEN dbo.Class_Events.event_typ
dbo.Class_Events.event_typ
CASE WHEN (dbo.Classes.ongoing =0) THEN Classes.Class_Start_Date WHEN dbo.classes.ongoing =1 THEN
(SELECT TOP 1 Class_events.Event_Date
FROM dbo.Class_Events
WHERE dbo.Class_Events.Class_Num
ORDER BY CASE WHEN dbo.Class_Events.event_typ
dbo.Class_Events.event_typ
CASE WHEN dbo.Classes.Status =''Classroom'' THEN ''Web-Assisted'' WHEN dbo.classes.status = ''OPEN'' THEN ''Web-Based'' ELSE ''All Other'' END AS Type,
CASE WHEN
dbo.Classes.ongoing =0 THEN Classes.Class_Start_Date WHEN dbo.Classes.ongoing=1 THEN Activity.Start_Date END AS Start_date,
dbo.Classes.teacher, dbo.Classes.Class_Start_Da
dbo.Students.Bureau_ID, dbo.Course_Definition.Cour
FROM dbo.Students INNER JOIN
dbo.Activity ON dbo.Students.Student_Numbe
dbo.bureau ON dbo.Students.Bureau_ID=dbo
dbo.Employee ON dbo.Students.employee_id = dbo.Employee.employee_ID INNER JOIN
dbo.Classes ON dbo.Activity.Class_Number = dbo.Classes.Class_Number INNER JOIN
dbo.Course_Definition ON dbo.Course_Definition.Cour
dbo.department ON dbo.Classes.department_id = dbo.department.department_
dbo.Instructors ON dbo.Classes.Instructor_Num
WHERE dbo.classes.Class_Number='
SET @s = @s +' order by ' + @sortby
if @oby <> ''
SET @s = @s + ' ' + @oby
EXEC(@s)
GO
ASKER CERTIFIED SOLUTION
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
ASKER
You are correct thank you It is the small things that we over look while in a rush
don't laugh, but I once spent over an hour trying to figure out why my new sp didn't execute correctly - turned out I was connected to the wrong server ;o)
any better with this:
CREATE PROCEDURE usp_Students_Report_Enroll
@class_number varchar(32),
@dept_id varchar(32)=0,
@sortby varchar(128) = 'last_name, first_name',
@oby varchar(32) = 'ASC'
AS
DECLARE @s varchar(1024)
SET @s = ' SELECT d.department_name, b.bureau_name, i.Instructor_name, c.deleted_class, cd.mandatory, e.lastname, e.firstname, c.Class_Number,
(SELECT TOP 1 ce.Event_Type
FROM dbo.Class_Events ce
WHERE ce.Class_Number = c.Class_Number
ORDER BY CASE WHEN ce.event_type = ''Passed Course'' THEN 1
WHEN ce.event_type = ''Past Test'' THEN 2
WHEN ce.event_type = ''Attempted Test'' THEN 3
ELSE 4 END DESC
) AS Event_Type,
CASE WHEN c.ongoing =0 THEN c.Class_Start_Date
WHEN c.ongoing =1 THEN
(SELECT TOP 1 ce.Event_Date
FROM dbo.Class_Events ce
WHERE ce.Class_Number = c.Class_Number
ORDER BY CASE WHEN ce.event_type = ''Passed Course'' THEN 1
WHEN ce.event_type = ''Past Test'' THEN 2
WHEN ce.event_type = ''Attempted Test'' THEN 3
ELSE 4 END
)
END AS completion_date,
CASE WHEN c.Status =''Classroom'' THEN ''Web-Assisted''
WHEN c.status = ''OPEN'' THEN ''Web-Based''
ELSE ''All Other''
END AS Type,
CASE WHEN c.ongoing =0 THEN c.Class_Start_Date
WHEN c.ongoing=1 THEN a.Start_Date
END AS Start_date,
c.teacher, c.Class_Start_Date, c.department_id, s.Student_Number,
s.Bureau_ID, cd.Course_Description, cd.Standard_Hours, c.Course_Number
FROM dbo.Students s
INNER JOIN dbo.Activity a
ON s.Student_Number = a.Student_Number
INNER JOIN dbo.bureau b
ON s.Bureau_ID=b.bureau_id
INNER JOIN dbo.Employee e
ON s.employee_id = e.employee_ID
INNER JOIN dbo.Classes c
ON a.Class_Number = c.Class_Number
INNER JOIN dbo.Course_Definition cd
ON cd.Course_Def_Number = c.Course_Number
INNER JOIN dbo.department d
ON c.department_id = d.department_id
INNER JOIN dbo.Instructors i
ON c.Instructor_Number=i.Inst ructor_num ber
WHERE c.Class_Number=' + @class_number
SET @s = @s +' order by ' + @sortby
if @oby <> ''
SET @s = @s + ' ' + @oby
EXEC(@s)
CREATE PROCEDURE usp_Students_Report_Enroll
@class_number varchar(32),
@dept_id varchar(32)=0,
@sortby varchar(128) = 'last_name, first_name',
@oby varchar(32) = 'ASC'
AS
DECLARE @s varchar(1024)
SET @s = ' SELECT d.department_name, b.bureau_name, i.Instructor_name, c.deleted_class, cd.mandatory, e.lastname, e.firstname, c.Class_Number,
(SELECT TOP 1 ce.Event_Type
FROM dbo.Class_Events ce
WHERE ce.Class_Number = c.Class_Number
ORDER BY CASE WHEN ce.event_type = ''Passed Course'' THEN 1
WHEN ce.event_type = ''Past Test'' THEN 2
WHEN ce.event_type = ''Attempted Test'' THEN 3
ELSE 4 END DESC
) AS Event_Type,
CASE WHEN c.ongoing =0 THEN c.Class_Start_Date
WHEN c.ongoing =1 THEN
(SELECT TOP 1 ce.Event_Date
FROM dbo.Class_Events ce
WHERE ce.Class_Number = c.Class_Number
ORDER BY CASE WHEN ce.event_type = ''Passed Course'' THEN 1
WHEN ce.event_type = ''Past Test'' THEN 2
WHEN ce.event_type = ''Attempted Test'' THEN 3
ELSE 4 END
)
END AS completion_date,
CASE WHEN c.Status =''Classroom'' THEN ''Web-Assisted''
WHEN c.status = ''OPEN'' THEN ''Web-Based''
ELSE ''All Other''
END AS Type,
CASE WHEN c.ongoing =0 THEN c.Class_Start_Date
WHEN c.ongoing=1 THEN a.Start_Date
END AS Start_date,
c.teacher, c.Class_Start_Date, c.department_id, s.Student_Number,
s.Bureau_ID, cd.Course_Description, cd.Standard_Hours, c.Course_Number
FROM dbo.Students s
INNER JOIN dbo.Activity a
ON s.Student_Number = a.Student_Number
INNER JOIN dbo.bureau b
ON s.Bureau_ID=b.bureau_id
INNER JOIN dbo.Employee e
ON s.employee_id = e.employee_ID
INNER JOIN dbo.Classes c
ON a.Class_Number = c.Class_Number
INNER JOIN dbo.Course_Definition cd
ON cd.Course_Def_Number = c.Course_Number
INNER JOIN dbo.department d
ON c.department_id = d.department_id
INNER JOIN dbo.Instructors i
ON c.Instructor_Number=i.Inst
WHERE c.Class_Number=' + @class_number
SET @s = @s +' order by ' + @sortby
if @oby <> ''
SET @s = @s + ' ' + @oby
EXEC(@s)
I see the issue is already solved :)
good job, Nightman
good job, Nightman
Thanks angelIII
statement length is the first thing I check with dynamic SQL syntax errors - it's almost ALWAYS overlooked ;)
statement length is the first thing I check with dynamic SQL syntax errors - it's almost ALWAYS overlooked ;)
yes, I usually check it also...
Scripter25, with my suggestion you might learn how to use table alias names, which makes your query shorter and usually more readable...
Scripter25, with my suggestion you might learn how to use table alias names, which makes your query shorter and usually more readable...
In future for debugging, replace EXEC (@s) with PRINT @s and see the output of what you would be executing.