标题:关于更新表的问题?
只看楼主
olderdream
Rank: 1
等 级:新手上路
帖 子:110
专家分:0
注 册:2009-3-17
结帖率:79.41%
已结贴  问题点数:20 回复次数:5 
关于更新表的问题?
想用下面的语句更新test表,可是不成功,红色部分出错,出现错误提示-----必须声明变量 '@mytable'。
请高手帮忙看看。多谢


declare @mytable table ([no] char(10),[score] char(10))
insert into @mytable
select '1','1298' union all
select '2','1298' union all
select '3','1297' union all
select '4','1298'

update test set score =(select score from @mytable )
where test.no=@mytable.no


test表结构
no    score
1    a
2    b
3    c
4    d
5    e
搜索更多相关主题的帖子: 关于更新表的问题? 
2009-07-16 11:06
olderdream
Rank: 1
等 级:新手上路
帖 子:110
专家分:0
注 册:2009-3-17
得分:0 
请高手指点
2009-07-16 17:58
球球
Rank: 6Rank: 6
等 级:贵宾
威 望:27
帖 子:1146
专家分:265
注 册:2005-11-28
得分:0 
不知道你要做什么

好累
2009-07-17 13:48
olderdream
Rank: 1
等 级:新手上路
帖 子:110
专家分:0
注 册:2009-3-17
得分:0 
建一个虚表“mytable”,并在其中insert into数据

之后,根据虚表的内容去更新数据库中的表test(把test中字段score更新---根据no字段)
2009-07-17 14:14
happynight
Rank: 8Rank: 8
等 级:贵宾
威 望:15
帖 子:807
专家分:760
注 册:2008-4-26
得分:20 
declare @mytable table ([no] char(10),[score] char(10))
insert into @mytable
select '1','1298' union all
select '2','1298' union all
select '3','1297' union all
select '4','1298'
--SELECT * FROM @mytable
--DROP TABLE #lS1
Create table #ls1 ([no] varchar(10),score varchar(10))

update #ls1 set score =a.score
from @mytable a
where #ls1.no=a.no
---------------------------------
还真没写过你这样的代码 在后面更新的话 确实必须要给表取别名 否则会出你那样的错误 另外 更新的写法 我比较习惯上面的方式 如果按照你的习惯的话 应该写成下面的样式
update #ls1 set score =(select score from @mytable a where #ls1.no=a.no)
2009-07-17 17:00
olderdream
Rank: 1
等 级:新手上路
帖 子:110
专家分:0
注 册:2009-3-17
得分:0 
回复 5楼 happynight
谢谢,搞定了。正对我的内容,如下:
declare @mytable table ([no] char(10),[score] char(10))
insert into @mytable
select '1','1298' union all
select '2','1298' union all
select '3','1297' union all
select '4','1298'

update test set score=a.score from  @mytable a where test.no=a.no
2009-07-17 17:40



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-279613-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.195851 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved