Динамический SQL для запроса таблицы Adventureworks - PullRequest
0 голосов
/ 07 апреля 2010

Я пытаюсь увидеть список таблиц из базы данных Adventureworks из схемы «Person» в Sql Server 2008. Я разработал следующий SP, но после его запуска следующим образом выдается ошибка «Неверный синтаксис рядом с ')'». Знаете ли вы, как я могу пересмотреть это заявление SP или exec?

CREATE PROCEDURE [getTableNames]
@SchemaName VARCHAR(50)
AS

BEGIN
SET NOCOUNT ON;
SET @SchemaName = 'PERSON'
DECLARE @cmd AS VARCHAR(max)
SET @SchemaName = RTRIM(@SchemaName)
SET @cmd = N'SELECT TABLE_NAME ' + 
'FROM information_schema.Tables ' +
'WHERE TABLE_TYPE = ''BASE TABLE'' AND TABLE_SCHEMA = @SchemaName'
END

exec sp_executesql getTableNames, N'@SchemaName NVARCHAR(50), @SchemaName'

Ответы [ 2 ]

3 голосов
/ 07 апреля 2010

Вам на самом деле не нужно использовать динамический SQL здесь, плюс ваш sproc не совсем прав, поскольку вы не выполняете оператор @cmd. Просто используйте:

CREATE PROCEDURE [getTableNames]
@SchemaName VARCHAR(50)
AS
BEGIN
    SET NOCOUNT ON
    SELECT TABLE_NAME 
    FROM information_schema.Tables
    WHERE TABLE_TYPE = 'BASE TABLE' AND TABLE_SCHEMA = @SchemaName
END

EXECUTE getTableNames 'PERSON'
1 голос
/ 07 апреля 2010

Вам не нужен динамический SQL:

select * from sys.tables
where type_desc = 'BASE TABLE' and schema_id = schema_id(@SchemaName)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...