Форум программистов, компьютерный форум, киберфорум
Наши страницы
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
bombermen
0 / 0 / 0
Регистрация: 07.04.2013
Сообщений: 12
1

Хранимая процедура с динамическим запросом и ошибка Incorrect syntax near '11'

11.08.2014, 12:29. Просмотров 1015. Ответов 1
Метки нет (Все метки)

Добрый день!

Имеется хранимая процедура с динамическим запросом:
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
ALTER PROCEDURE sdsd
@dateBegin datetime,
@Tab varchar(20)
 
AS BEGIN
    SET NOCOUNT ON;
    EXEC ('  
SELECT *
FROM '+@Tab+'
WHERE CDate = '+@dateBegin+'
   ')
END
Вызываю так
T-SQL
1
EXEC sdsd '08.11.2014', 'BookkeepingOutCome'
В качестве параметров передаются дата и текущая таблица
Этот код не работает.Выдает ошибку

Сообщение 102, уровень 15, состояние 1, строка 4
Incorrect syntax near '11'.
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.08.2014, 12:29
Ответы с готовыми решениями:

Процедура с динамическим запросом
Требуется написать процедуру, которой будет передаваться через запятую цифры и...

Не создается хранимая процедура с запросом. Operand type clash: int is incompatible with cursor
Пишешь процедуру : SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON GO CREATE...

Хранимая процедура - ошибка новичка
ALTER PROCEDURE . — Add the parameters for the stored procedure here...

Хранимая процедура - ошибка при сохранении
Всем привет! Скажите, пожалуйста, что мне надо исправить в моей хранимой...

Ошибка Cannot convert a char value to money. The char value has incorrect syntax
В отчете (ниже) появляется ошибка Cannot convert a char value to money. The...

1
iap
888 / 616 / 127
Регистрация: 27.11.2009
Сообщений: 1,828
11.08.2014, 12:47 2
Лучший ответ Сообщение было отмечено bombermen как решение

Решение

T-SQL
1
2
3
4
5
6
ALTER PROCEDURE sdsd @dateBegin datetime, @Tab varchar(20) AS
 SET NOCOUNT ON;
 EXEC(N'  
SELECT *
FROM '+@Tab+N'
WHERE CDate = '''+@dateBegin+N'''');
Дата, представленная литеральной строкой, должна быть в одинарных кавычках.
Применяйте при вызове стандартный формат без разделителей:
T-SQL
1
EXEC sdsd '20141108', 'BookkeepingOutCome';
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.08.2014, 12:47

Ошибка в запросе - "Incorrect syntax near ','"
Всем привет, не могу понять ошибку в запросе, база работает на SQL Server 2003....

Incorrect syntax near
Всем доброго времени суток. Пытаюсь с помощью запроса в MS SQL Server...

Хранимые процедуры с динамическим запросом
Доброго времени суток, уважаемые форумчане! Может у меня проблемы с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru