请问什么样的变量不用定义

[复制链接]
查看11 | 回复2 | 2011-4-13 12:08:17 | 显示全部楼层 |阅读模式
我一直以为pl/sql procedure、function或者anonymouse block里用到的变量都是要先定义再可以使用的,但为什么下面这个程序没有错呢?我的问题是pl/sql中什么样的变量不用定义,哪里有关于这个问题的介绍?
这段程序里的i不用定义为什么可以使用:
BEGIN
FOR i IN 1 .. 100 LOOP
dbms_output.put_line(i);
END LOOP;
END;
复制代码

这里的i不定义为什么就出错?
BEGIN
i := 'hello';
dbms_output.put_line(i);
END;
复制代码
回复

使用道具 举报

千问 | 2011-4-13 12:08:17 | 显示全部楼层
循环语句能自己创建循环变量 当所指定的变量不存在的时候会发生这种情况
参考Oracle Database 10g SQL 开发指南295页
回复

使用道具 举报

千问 | 2011-4-13 12:08:17 | 显示全部楼层
for i in 1 .. 10 这意思是i在1 .. 10中,oracle自动就知道是什么类型的了,俗称index_name
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

主题

0

回帖

4882万

积分

论坛元老

Rank: 8Rank: 8

积分
48824836
热门排行