当前位置: 代码迷 >> Sql Server >> 怎么建变量放入临时表中
  详细解决方案

怎么建变量放入临时表中

热度:62   发布时间:2016-04-25 00:42:32.0
怎样建变量放入临时表中
如下所示:
R是一张原本就有的表,有如下字段:idno(主键)、name、sex、age、grade

 Create #Temp
(
  idtep  int
  nametep nvarchar(30)
  gradetep numeric(4,2)
)

Declare @name nvarchar(30)
Declare @id int
Declare @grade numeric(4,2)
Declare my_cursor Cursor Scroll for
select * from R 
open my_cursor
While @@fetch_status = 0
begin
select id,name,grade from R where sex = '额' 
fetch next from my_cursro into @name,@id,@grade
end
close my_cursor
deallocate my_cursor

我想把通过游标遍历的R表中,所有sex为‘额’的同学的id,name,grade取出来然后放入临时表中,让每一个idTed = @id; nameTep = @name; gradeTep = @grade(注:这里必须用游标)

求教,求教!
------最佳解决方案--------------------
你不懂insert into 语法啊

insert 表名(字段名字列表)
values(与字段名字对应的值)

insert #tb(name)
value(@name)
------其他解决方案--------------------
 Create #Temp
(
  idtep  int
  nametep nvarchar(30)
  gradetep numeric(4,2)
)
 
Declare @name nvarchar(30)
Declare @id int
Declare @grade numeric(4,2)
Declare my_cursor Cursor Scroll for
select * from R 
open my_cursor
While @@fetch_status = 0
begin
select id,name,grade from R where sex = '额' 
fetch next from my_cursro into @name,@id,@grade
insert #Temp--这里
values(@id,@name,@grade)--这里
end
close my_cursor
deallocate my_cursor

------其他解决方案--------------------
引用:
SQL code?12345678910111213141516171819202122 Create #Temp(  idtep  int  nametep nvarchar(30)  gradetep numeric(4,2))  Declare @name nvarchar(30)Declare @id intDeclare @grade numeric(4,2)D……

感谢版主大人!那如果麻烦一点:只把一个字段插入到临时表中呢?就是说,临时表中不是有三个字段:idTep、nameTep、gradeTep,我只是想把@name插入到临时表中,而@id、@grade完全可以不用取出来了,因为我不需要它现在插入临时表中,那么应该怎么做?(当然可以见临时表的时候只建idTep一个字段,但是我要nameTep、gradeTep还有别用,不能不建)
------其他解决方案--------------------
谢谢版主!!!我明白了!
  相关解决方案