用存储过程动态生成表

nicole_lixp 2005-05-04 09:22:43
我在ASP中想动态生成个表,用存储过程

CREATE PROCEDURE CreatTable ( @tableName nvarchar(20), @data nvarchar(50))
AS

CREATE TABLE @tableName (
ProjectResource nvarchar(70) NOT NULL ,
primary key (ProjectResource));
insert @tableName
values(@data)
GO

可它说“@tableName”未定义!高手帮帮忙啊!
...全文
97 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
mschen 2005-05-04
  • 打赏
  • 举报
回复
--应该使用动态语句来执行

CREATE PROCEDURE CreatTable ( @tableName nvarchar(20), @data nvarchar(50))
AS
DECLARE @STR_SQL varchar(8000)
SET @STR_SQL='CREATE TABLE '+@tableName+' (
ProjectResource nvarchar(70) NOT NULL ,
primary key (ProjectResource))'
EXEC(@STR_SQL)
SET @STR_SQL=
'insert '+@tableName+'values(@data)'
EXEC(@STR_SQL)
GO
talantlee 2005-05-04
  • 打赏
  • 举报
回复
CREATE PROCEDURE createtable
@a varchar(100)

AS
exec('create table '+@a
+'(a int,b int)')
GO
云中客 2005-05-04
  • 打赏
  • 举报
回复
表名不能用变量,试写成一个字串,然后执行他

34,588

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧