oraclesqlfor
A. oracle sql怎么写循环语句
declare
sql_tem Varchar2(4000);
a number;
b number;
i number;
begin
a := 1;
for i in 1 .. 3 loop
b := a + 4;
sql_tem := 'insert into A2 (ID,NAME) (select ID,NAME from A1 WHERE ROWNUM between :1 and :2)';
EXECUTE IMMEDIATE sql_tem
USING a, b;
commit;
a := a + 5;
end loop;
end;
试试上面的代码看一下能不能满意你的要求先呗。。。
B. Oracle下如何用sql创建游标
For 循环游标
(1)定义游标
(2)定义游标变量
(3)使用for循环来使用这个游标
declare
--类型定义
cursorc_job
is
selectempno,ename,job,sal
fromemp
wherejob='MANAGER';
--定义一个游标变量v_cinfoc_emp%ROWTYPE,该类型为游标c_emp中的一行数据类型
c_rowc_job%rowtype;
begin
forc_rowinc_jobloop
dbms_output.put_line(c_row.empno||'-'||c_row.ename||'-'||c_row.job||'-'||c_row.sal);
endloop;
end;
Fetch游标
使用的时候必须要明确的打开和关闭
declare
--类型定义
cursorc_job
is
selectempno,ename,job,sal
fromemp
wherejob='MANAGER';
--定义一个游标变量
c_rowc_job%rowtype;
begin
openc_job;
loop
--提取一行数据到c_row
fetchc_jobintoc_row;
--判读是否提取到值,没取到值就退出
--取到值c_job%notfound是false
--取不到值c_job%notfound是true
exitwhenc_job%notfound;
dbms_output.put_line(c_row.empno||'-'||c_row.ename||'-'||c_row.job||'-'||c_row.sal);
endloop;
--关闭游标
closec_job;
end;
C. 在oracle中通过for循环得到近6个月的时间,下面sql说缺少into,不知道该怎么加,求指教,我没悬赏值了
你是写在function中或是procere中的吧?select后面不能用as,只能用into,定义一个变量来接受这个日期
D. Oracle PL/SQL 局一中的FOR语句: 用for语句求得前100个自然数中偶数和。
mod(x,y)函数的意义是 求x除以y的余数,例如mod(5,2)=1,5除以2余1,mod(2,2)=0, 2除以2等于1余数是0,所以答案是0,这个程序块就是利用这样的求余的原理来循环判断1-100之间的偶数,凡是能被2除尽的就是偶数。
代码中FOR循环100次,i从100开始反向循环,99,98··以此类推到1截止退出循环。
if mod(i,2)=0 --
mod(i,2)=0的意思是i除以2无余数,如果无余数,则说明i是偶数(只有偶数除以2才能除尽)。
then s:=s+i; --
那么变量s加上这个偶数i变成新的s,进入到下一个循环判断,若非偶数直接进入下个循环,若为偶数s的值累加,直到循环结束,100以内所有的偶数累加成为最终的变量S。
E. 用oracle SQL 查询结果集 用集循环 并用集的列做if条件 满足条件后集的列批量插
declare
cursor my_cursors is select * from t1 where 1=1 --定义游标
my_cursor varchar2(40); --这个数据类型根据自己的情况修改。
begin
for my_cursor in my_cursors loop
if my_cursor.n1=1 then
---做你的循环里内容
end if;
end loop;
end
F. oracle sql developer的安装过程和使用说明
1、首先,需要去官网下载64位的sql developer。接收协议后,选择64位的点击“下载”。
(6)oraclesqlfor扩展阅读:
oracle sql developer优点:
1、完全免费微软数据库培训无需任何启动资金和预算,学生也不需要任何费用。在原来的程序上进行免费升级,并且在官方论坛上有一些免费的技术支持。
2、随处运行
Windows、OSX(Apple)、Unix、Linux。也不需要在实验室机器上启动Windows VM去运行Windows软件。
3、谁都可以安装
无需安装,无需注册便可以更新,无需管理员权限即可获得。可以下载或者提取一些文件在电脑或者U盘里面,就可以运行。这里有一个视频教程,怎样开始使用。有可能5分钟以后就学会使用Oracle SQL Developer。
4、无处不在
SQL Developer无处不在,在去年,它已经有超过250万用户下载并且是OTN上下载最多的软件。这也就意味着,需要帮助的时候,身边就有人能帮助。
5、简单的用户接口
连接,查看对象或者点击对象。可以使用工作表去写查询语句或者程序。这里只有一个工具条,而且上面仅仅只有几个按钮。只想要“A”、“B”、“SELECT”和“START”控制就行了。如果是Oracle新手,建议不要同时学习新的工具来增加学习压力。
6、它不是一个“黑盒子”
就像平时使用向导完成任务一样,也可以通过拖拽表来实现查询等操作,并且还可以查看生成好的SQL语句。请不要因为有一个GUI可以使数据库正常工作就放弃学习底层的代码。
7、“四合一”
它不仅仅是查询工具,有可能也需要去设计一个数据模型,或者为了新的项目需要迁移Sybase ASE数据库,又或许需要建一些报表,以上这些Oracle SQL Developer都可以满足。所以一旦习惯了使用这个工具后,其余的都可以轻而易举实现。
8、丰富的资源
视频,博客,论坛等,随处都可以找到。
参考资料:
网络—oracle sql developer
G. Oracle中使用PL/SQL怎样用循环插入多条数据
使用loop循环,比如:
for item in (select a,b,c from table_a where 条件) loop
insert into table_b(a,b,c) values (item.a,item.b,item.c);
end loop;
也可以使用索引表循环,以上只是一个简单的例子,需要根据你的具体情况选择循环方式。
H. oracle存储过程中循环for in是如何使用的
1、首先编写存储过程的整体结构,如下图所示定义变量。
I. oracle存储过程循环执行SQL语句
实现方式错了,批量移动数据应该使用Cursor,而不是像分页那样每次都查询。
每次都查询可能会导致重复数据。
正确方式应该是打开一个Cursor,循环Cursor来插入,使用计数器来控制每次COMMIT的行数:
declare
TYPE R_CURSOR IS REF CURSOR;
i number;
a1_cursor R_CURSOR;
a1_row A1%ROWTYPE;
begin
open a1_cursor FOR
select ID, NAME from A1;
i := 0;
loop
fetch a1_cursor
into a1_row;
exit when a1_cursor%notfound;
INSERT INTO A2 VALUES a1_row;
i := i + 1;
if i >= 5 then
commit;
i := 0;
end if;
end loop;
close a1_cursor;
commit;
end;