| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 663 人关注过本帖
标题:关于更新表的问题?
取消只看楼主 加入收藏
olderdream
Rank: 1
等 级:新手上路
帖 子:110
专家分:0
注 册:2009-3-17
结帖率:79.41%
收藏
已结贴  问题点数:20 回复次数:3 
关于更新表的问题?
想用下面的语句更新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
olderdream
Rank: 1
等 级:新手上路
帖 子:110
专家分:0
注 册:2009-3-17
收藏
得分:0 
建一个虚表“mytable”,并在其中insert into数据

之后,根据虚表的内容去更新数据库中的表test(把test中字段score更新---根据no字段)
2009-07-17 14:14
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
快速回复:关于更新表的问题?
数据加载中...
 
   



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

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