首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于查询Adventureworks表的动态SQL

用于查询Adventureworks表的动态SQL
EN

Stack Overflow用户
提问于 2010-04-07 04:22:28
回答 2查看 522关注 0票数 0

我正在尝试从Sql Server2008中的"Person“架构查看Adventureworks DB中的表列表。我开发了下面的SP,但是按照下面的方式运行之后,它给出了错误“‘)’附近的语法不正确”。您知道如何修改此SP或exec语句吗?

代码语言:javascript
复制
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'
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-04-07 04:32:50

您不需要动态SQL:

代码语言:javascript
复制
select * from sys.tables
where type_desc = 'BASE TABLE' and schema_id = schema_id(@SchemaName)
票数 1
EN

Stack Overflow用户

发布于 2010-04-07 04:31:49

您实际上不需要在这里使用动态SQL,而且您的sproc并不是很正确,因为您没有执行@cmd语句。只需使用:

代码语言:javascript
复制
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'
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2588013

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档