0

我正在尝试从 Sql Server 2008 中的“Person”架构中查看 Adventureworks DB 中的表列表。我开发了以下 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'
4

2 回答 2

3

您实际上不需要在这里使用动态 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'
于 2010-04-06T20:31:48.610 回答
1

您不需要动态 SQL:

select * from sys.tables
where type_desc = 'BASE TABLE' and schema_id = schema_id(@SchemaName)
于 2010-04-06T20:32:49.590 回答