0

Sql Server 2008 の "Person" スキーマから Adventureworks DB のテーブルの一覧を表示しようとしています。次の SP を開発しましたが、次のように実行すると、"Incorrect syntax near ')'" というエラーが表示されます。この 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 を使用する必要はありません。また、@cmd ステートメントを実行していないため、sproc は正しくありません。使用するだけです:

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 に答える