首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
MS SQL Server
» SQL Server 2000中是否有FOR 循环语句???
‹‹ 上一主题
|
下一主题 ››
投票
交易
悬赏
活动
电梯
|
好评
|
打印
|
推荐
|
订阅
|
收藏
标题: SQL Server 2000中是否有FOR 循环语句???
etqxq
中级会员
精华贴数 1
个人空间
0
技术积分 843 (2287)
社区积分 0 (72162)
注册日期 2002-11-29
论坛徽章:0
#1
使用道具
发表于 2004-3-7 15:32
SQL Server 2000中是否有FOR 循环语句???
for i=0,i++,i<@num
select dateadd(DAY,GETDATE(),I)
请问上面的语句怎么改写才正确???
感谢!!!
etqxq@hotmail.com
__________________
qxq
ccwlm741212
老男人
精华贴数 40
个人空间
0
技术积分 31757 (27)
社区积分 54249 (9)
注册日期 2002-11-25
论坛徽章:124
#2
使用道具
发表于 2004-3-7 18:37
Transact-SQL 参考
WHILE
设置重复执行 SQL 语句或语句块的条件。只要指定的条件为真,就重复执行语句。可以使用 BREAK 和 CONTINUE 关键字在循环内部控制 WHILE 循环中语句的执行。
语法
WHILE Boolean_expression
{ sql_statement | statement_block }
[ BREAK ]
{ sql_statement | statement_block }
[ CONTINUE ]
参数
Boolean_expression
返回 TRUE 或 FALSE 的表达式。如果布尔表达式中含有 SELECT 语句,必须用圆括号将 SELECT 语句括起来。
{sql_statement | statement_block}
Transact-SQL 语句或用语句块定义的语句分组。若要定义语句块,请使用控制流关键字 BEGIN 和 END。
BREAK
导致从最内层的 WHILE 循环中退出。将执行出现在 END 关键字后面的任何语句,END 关键字为循环结束标记。
CONTINUE
使 WHILE 循环重新开始执行,忽略 CONTINUE 关键字后的任何语句。
注释
如果嵌套了两个或多个 WHILE 循环,内层的 BREAK 将导致退出到下一个外层循环。首先运行内层循环结束之后的所有语句,然后下一个外层循环重新开始执行。
示例
A. 在嵌套的 IF...ELSE 和 WHILE 中使用 BREAK 和 CONTINUE
在下例中,如果平均价格少于 $30,WHILE 循环就将价格加倍,然后选择最高价。如果最高价少于或等于 $50,WHILE 循环重新启动并再次将价格加倍。该循环不断地将价格加倍直到最高价格超过 $50,然后退出 WHILE 循环并打印一条消息。
USE pubs
GO
WHILE (SELECT AVG(price) FROM titles) < $30
BEGIN
UPDATE titles
SET price = price * 2
SELECT MAX(price) FROM titles
IF (SELECT MAX(price) FROM titles) > $50
BREAK
ELSE
CONTINUE
END
PRINT 'Too much for the market to bear'
B. 在带有游标的过程中使用 WHILE
以下的 WHILE 结构是名为 count_all_rows 过程中的一部分。下例中,该 WHILE 结构测试用于游标的函数 @@FETCH_STATUS 的返回值。因为 @@FETCH_STATUS 可能返回 –2、-1 或 0,所以,所有的情况都应进行测试。如果某一行在开始执行此存储过程以后从游标结果中删除,将跳过该行。成功提取 (0) 后将执行 BEGIN...END 循环内部的 SELECT 语句。
USE pubs
DECLARE tnames_cursor CURSOR
FOR
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
OPEN tnames_cursor
DECLARE @tablename sysname
--SET @tablename = 'authors'
FETCH NEXT FROM tnames_cursor INTO @tablename
WHILE (@@FETCH_STATUS <> -1)
BEGIN
IF (@@FETCH_STATUS <> -2)
BEGIN
SELECT @tablename = RTRIM(@tablename)
EXEC ('SELECT ''' + @tablename + ''' = count(*) FROM '
+ @tablename )
PRINT ' '
END
FETCH NEXT FROM tnames_cursor INTO @tablename
END
CLOSE tnames_cursor
DEALLOCATE tnames_cursor
请参见
ALTER TRIGGER
控制流语言
CREATE TRIGGER
游标
SELECT
©1988-2000 Microsoft Corporation。保留所有权利。
__________________
参悟佛理~~智慧做人~~谈泊明心~~宽容博大~~除妄去执~~知恩重义
lynx286
陈永仁
精华贴数 0
个人空间
0
技术积分 1665 (1030)
社区积分 151 (2821)
注册日期 2003-7-23
论坛徽章:10
#3
使用道具
发表于 2004-3-8 08:34
declare @i int,
@num int
set @i=1
set @num=20
while @i<@num
begin
select dateadd(DAY,@i,GETDATE())
set @i=@i+1
end
__________________
专业的中文数据仓库,商务智能社区 http://www.mydwbi.com
etqxq
中级会员
精华贴数 1
个人空间
0
技术积分 843 (2287)
社区积分 0 (72162)
注册日期 2002-11-29
论坛徽章:0
#4
使用道具
发表于 2004-3-8 15:09
感谢大家的回复!
我已经搞定此问题,
祝大家工作顺利!!
身体健康!!!
__________________
qxq
woodlin
一般会员
精华贴数 0
个人空间
0
技术积分 342 (5806)
社区积分 0 (106419)
注册日期 2004-2-6
论坛徽章:0
#5
使用道具
发表于 2004-3-9 08:46
我昨天也刚用过这语句,很好用。
piaoye123
一般会员
精华贴数 0
个人空间
0
技术积分 188 (10081)
社区积分 0 (932107)
注册日期 2006-5-15
论坛徽章:0
#6
使用道具
发表于 2006-11-23 14:06
我怎麼沒起作用呢?
alter procedure time_by
as
Declare @Count Int
Set @Count=1099
While @Count>=4298
Begin
update Time_by_day set Time_ID=(@Count-1098) where Time_ID=@Count
Set @Count=@Count+1
CONTINUE
End
execute time_by
__________________
BI,真的不懂
hincorany
一般会员
精华贴数 0
个人空间
0
技术积分 148 (12431)
社区积分 0 (1176108)
注册日期 2006-11-9
论坛徽章:0
#7
使用道具
发表于 2006-11-24 10:01
QUOTE:
最初由 piaoye123 发布
我怎麼沒起作用呢?
alter procedure time_by
as
Declare @Count Int
Set @Count=1099
While @Count>=4298
Begin
update Time_by_day set Time_ID=(@Count-1098) where Time_ID=@Count
Set @Count=@Count+1
CONTINUE
End
execute time_by
初值1099就不满足@count>=4298当然不执行循环
另外continue在你的存储过程中没用……
那个是用在你要跳过循环内后面的语句继续循环才用的。
__________________
保护环境珍爱自然愿平衡与您同在
brage
来自 上海
精华贴数 0
个人空间
0
技术积分 44 (31343)
社区积分 0 (1761477)
注册日期 2008-4-18
论坛徽章:0
#8
使用道具
发表于 2008-6-15 22:45
感觉挺好用的
现在如果某字段中出现相同的值,如何用循环现实该字段相同字段值的操作?例如:
id name
1 a
1 b
1 c
2 d
2 e
结果为:
id name
1 abc
2 de
投票
交易
悬赏
活动
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Fusion中间件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> Oracle EBS R12
> PeopleSoft与JDE
> EBS相关文档
> SAP R/3
> SAP Business One开发与快速实施
> SAP财务及CRM
> SAP后勤及HR
> mySAP ERP
> 系统开发及跨应用设置
> SAP相关文档
> 国外其它ERP产品
> 国内ERP产品
≡ 开发技术 ≡
> Java入门与认证版
> Java web开发及框架技术
> Java企业开发
> ASP.NET【已迁移到微软开发技术论坛】
> .Net企业开发与应用【已迁移到微软开发技术论坛】
> WEB程序开发
> WEB 2.0技术
> 动态语言
> 移动与游戏开发
≡ 系统设计与项目管理 ≡
> 系统分析与UML
> 系统分析与UML精华区
> 项目管理
> 项目过程
> 软件测试
> 算法讨论与研究
≡ IBM软件技术园地 ≡
> IBM数据库产品
> Lotus
> Tivoli
> Websphere
> Rational
> 与SOA相关的IBM产品与技术
> IBM软件技术精英协会
> 软件技术精英活动专版
≡ 操作系统与硬件 ≡
> AIX及IBM产品【已迁移到IXPUB】
> HP-UX及HP产品【已迁移到IXPUB】
> Solaris及SUN产品【已迁移到IXPUB】
> Linux及其应用 【已迁移到IXPUB】
> 其它UNIX系统【已迁移到IXPUB】
> windows系统及微软相关产品 【已迁移到IXPUB】
> 存储设备与容灾技术 【已迁移到IXPUB】
> 服务器 【已迁移到IXPUB】
≡ 行业纵向讨论区 ≡
> IT业界评论与展望
> 政府与教育事业
> 中国政府信息主管联盟
> 电信行业
> 金融行业
> 医卫行业
> 制造行业
> 电力行业
> 信息安全与审计
≡ 会员交流 ≡
> IT职业生涯
> 招聘求职商务信息
> 体育世界
> 体育博彩专版
> 旅游,驴友
> 汽车世界
> 外语角
> 数码摄影
> 你的故事我的歌
> 音乐推荐区
> 电子图书与IT文档资料
> 软件交流
> 软件交流精华区
≡ ITPUB产品与服务 ≡
> ITPUB地面活动专版
> BLOG天地
> WIKI世界
> 授权用户区
> 站务管理
≡ 微软开发技术 ≡
> 开发工具和语言
> .NET Framework 相关
> Visual Basic/VB.net
> Visual C#
> Visual C++/vc.net
> Visual Studio
> .NET软件架构与模式
> .NET开发辅助工具及框架
> Web开发
> ASP.NET与AJAX
> Web相关技术讨论(IIS等)
> Silverlight 技术
> 微软企业级产品技术
> SQL Server
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> Office开发
> Microsoft office system
> Office Business Application
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计