当前位置: 移动技术网 > IT编程>数据库>MSSQL > mssql存储过程表名和字段名为变量的实现方法

mssql存储过程表名和字段名为变量的实现方法

2017年12月12日  | 移动技术网IT编程  | 我要评论
没有使用动态语句直接报错 错误的 复制代码 代码如下: alter proc testpapers as begin declare @tems nvarchar(max)
没有使用动态语句直接报错

错误的
复制代码 代码如下:

alter proc testpapers
as
begin
declare @tems nvarchar(max),@zidaun nvarchar(max)
set @tems=select * from @tems order by @zidaun
exec(@tems)
end
exec testpapers

消息 156,级别 15,状态 1,过程 testpapers,第 1 行
关键字 'select' 附近有语法错误。
消息 1087,级别 15,状态 2,过程 testpapers,第 1 行
必须声明表变量 "@tems"。

首先要让表名或者字段为变量则要用到动态语句

错误的
复制代码 代码如下:

alter proc testpapers
as
begin
declare @tems nvarchar(max),@zidaun nvarchar(max)
set @tems='select * from @tems order by @zidaun ';
exec(@tems)
end

exec testpapers

消息 1087,级别 15,状态 2,第 1 行
必须声明表变量 "@tems"。

将表名和字段名写到exec里边

正确的
复制代码 代码如下:

alter proc testpapers
as
begin
declare @startrow nvarchar(max),@tems nvarchar(max),@zidaun nvarchar(max)
set @startrow='temp'
set @tems='select * from ';
set @zidaun='p_id';
exec(@tems+@startrow+' order by '+@zidaun)
end

exec testpapers

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网