在尝试做在线考试系统的过程中,为了管理每个学生的考试信息,就考虑为每个学生创建以学号命名的临时数据表。
在存储过程中动态创建表如果不使用参数的话很好创建。方法如下:
alter procedure [dbo].[ZXKS_GETSCORE] AS begin transaction –创建临时表,直接命名 create table temp_tablename ( id int primary key, da varchar(300), fs int ) declare @count int select @count=@@error if(@count=0) commit transaction else rollback transaction |
如果要将传入参数作为数据表名的话,就会遇到一个问题:如果表名是数字那么SQL SERVER 2005认不出来,会提示错误。必须将数字的表名前加上非数字的字符。存储过程如下所示:
/* createtable ’123456’ */ |
alter procedure createtable @xuehao varchar(20) as declare @tablename varchar(20) set @tablename=’temp’+@xuehao exec(’create Table ’+@tablename+’ ( name nvarchar(15), address nvarchar(50) )’) |
并且将参数作为数据表名的话,创建方法要使用exec方法,使用前面介绍的那个方法行不通。
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
TechTarget
官方微博
TechTarget中国
相关推荐
-
TT百科:存储过程
存储的过程可以访问或修改数据库中的数据,但并不绑定到特定的数据库或对象,这提供了许多优点。
-
解决创建动态表时的PL/SQL错误
创建的表不会动态地出现在编译时(compile time)里。任何模式对象的静态引用都需要在编译时中进行验证。
-
在Oracle数据库的自定义函数中调用存储过程
在Oracle数据库的自定义函数中调用存储过程是否可行,Oracle专家Brian Peasland给出了具体的解答。
-
数据库工程师2012年3月刊:数据库2012
数据库的2012,不是末日而是新生。传统厂商纷纷发布大版本更新的数据库产品,开源技术更加强势,2012的精彩始于《数据库工程师》……