求一个有挑战性的存储过程
参数1:sql= "select   mb   from   user   whete   sf= '上海 ' " 
 参数2:msg= "短信测试 " 
 传递以上2个参数给存储过程,写入以下2个表的记录   
 表1:mission:   id,misname,msg,date   (其中misname用日期生成,msg=@msg)               
 表2:mission_list:   id,misid,mb   (其中misid=mission.id   上表刚刚新增的id   ,mb为sql语句查询所得的值)   
 表1是一条记录,记忆任务和短信内容 
 表2是多条记录,记忆手机号和该任务的id   
------解决方案--------------------create proc procT  
     @sql nvarchar(1000), 
     @msg nvarcahr(100) 
 as 
     declare @I decimal(10,0) 
     begin tran 
     insert mission select convert(varchar(10),getdate,112),@msg,getdate() 
     set @I=select max(id) from mission 
     exec( 'insert mission_list select  ' +ltrim(@I)+ ',* from ( '+@sql+ ') aa ') 
     commit tran 
 go
------解决方案--------------------需要用动态SQL语句。   
 两个表追加,需要用事务,注意设置Set Xact_abort on,以保证事务处理的完整性。     
 动态sql语句基本语法  
 1 :普通SQL语句可以用Exec执行    
 eg:   Select * from tableName  
          Exec( 'select * from tableName ')  
          Exec sp_executesql N 'select * from tableName '    -- 请注意字符串前一定要加N    
 2:字段名,表名,数据库名之类作为变量时,必须用动态SQL    
 eg:    
 declare @fname varchar(20)  
 set @fname =  'FiledName '  
 Select @fname from tableName              -- 错误,不会提示错误,但结果为固定值FiledName,并非所要。  
 Exec( 'select  ' + @fname +  ' from tableName ')     -- 请注意 加号前后的 单引号的边上加空格    
 当然将字符串改成变量的形式也可  
 declare @fname varchar(20)  
 set @fname =  'FiledName ' --设置字段名    
 declare @s varchar(1000)  
 set @s =  'select  ' + @fname +  ' from tableName '  
 Exec(@s)                -- 成功  
 exec sp_executesql @s   -- 此句会报错      
 declare @s Nvarchar(1000)  -- 注意此处改为nvarchar(1000)  
 set @s =  'select  ' + @fname +  ' from tableName '  
 Exec(@s)                -- 成功      
 exec sp_executesql @s   -- 此句正确    
 3. 输出参数  
 declare @num int,  
         @sqls nvarchar(4000)  
 set @sqls= 'select count(*) from tableName '  
 exec(@sqls)  
 --如何将exec执行结果放入变量中?    
 declare @num int,  
                @sqls nvarchar(4000)  
 set @sqls= 'select @a=count(*) from tableName  '  
 exec sp_executesql @sqls,N '@a int output ',@num output  
 select @num    
------解决方案--------------------create procedure test(@sql varchar,@msg varchar) 
 as 
 begin 
  declare @ID int 
     begin tran 
     insert into mission values(convert(varchar(10),getdate(),120),@msg,convert(varchar(20),getdate(),120)) 
     set @ID=select max(id) from mission 
     exec( 'insert mission_list values( ' +Convert(varchar,@ID)+ ',* from ( '+@sql+ ')) ') 
     commit tran   
 end
------解决方案--------------------try:   
 create procedure p_1 @sql varchar(8000),@msg varchar(8000) 
 as 
 declare @id int,@id2 int 
 select @id=isnull(max(id),0) from mission 
 set @id=@id+1 
 insert into mission(id,misname,msg,date) values(@id,getdate(),@msg,getdate()) 
 select @id2=isnull(max(id),0) from mission_list 
 set @id2=@id2+1 
 exec(@sql) 
 exec( 'insert into mission_list(id,misid,mb) select  '+cast(@id2 as varchar)+ ', '+cast(@id as varchar)+ ',( '+@sql+ ') ') 
 go