Home Database Mysql Tutorial Oracle游标(CURSOR)

Oracle游标(CURSOR)

Jun 07, 2016 pm 05:13 PM

PL/SQL包含两种游标:1.显示游标 2.隐式游标 显示游标:语法: CUROSR cursor_name is select_statement;打开游标:open cursor_

PL/SQL包含两种游标:1.显示游标 2.隐式游标

显示游标:
语法:
CUROSR cursor_name is select_statement;
打开游标:open cursor_name;
提取数据:两种:1.FETCH curosr_name INTO varible1,variable2....;
       2.FETCH cursor_name BULK COLLECT INTO  collect1,collect2,....[LIMIT rows];
关闭游标:CLOSE cursor_name;

显示游标属性:
1.%ISOPEN:该属性用于确定游标是否已经打开。如果打开,返回true, 否则返回false;
2.%FOUND:该属性检查是否从数据集中提取到了数据。有数据为true,反之为false;
3.%NOTFOUND:与%FOUND相反。
4.%ROWCOUNT:返回当前行为已经提取到的实际行数。

注意:1.当用FETCH已经取到游标的末尾时,再对游标进行取值,游标会返回结果集中的最后一条记录,因为,当游标再结果集中取不到值时会返回给用户游标缓冲区的内容(也就是结果集中的最后一条记录);
2.以上的属性只针对于游标的当前状态。
3.之前的嵌套表、变长数组的使用都是需要初始化的,这里注意的是:当在显示游标中使用FETCH语句对嵌套表或变长数组赋值时,是不需要初始化大小的。

参数游标:
语法:CURSOR cursor_name(parameter_name datatype)IS select_statement;
1.对于游标的参数可以使用DEFAULT关键字对参数设置默认值,调用时若不给此参数传值,则会调用默认值。
2.对参数游标进行取值时只能用FETCH(一般的游标,可以使用for遍历取值);

使用游标更新或删除数据:
语法:(更新)UPDATE table_name SET column=.. WHERE CURRENT OF cursor_name;
     (删除)DELETE FROM table_name WHERE CURRENT OF cursor_name;
1.在对 游标进行更行时需要在游标语法后面加上 for update [,WAIT num][,OF col];
解析:for update:表名此游标对所使用的表独占,防止其他人对此表同时操作。
      wait:wait 秒数,,指当所操作的表被锁定时,等待几秒再执行,若依然是锁定状态,则会抛出异常,可以设置为NOWAIT不需要等待。
      OF col:列级锁,使用此锁的列所在的一行记录都被锁定。

游标变量:
语法:TYPE ref_type_name IS CURSOR [RETURN return_type];
创建完类型后要使用需要声明:cursor_name ref_type_name;
打开游标:OPEN cursor_name for select_statement;
使用FETCH取值:与显示游标一样。
关闭游标:与显示游标一样。

语法解析:
[RETURN return_type]:类型限制,只能返回限定的数据类型;

更多Oracle相关信息见Oracle 专题页面 ?tid=12

linux

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How do you alter a table in MySQL using the ALTER TABLE statement? How do you alter a table in MySQL using the ALTER TABLE statement? Mar 19, 2025 pm 03:51 PM

The article discusses using MySQL's ALTER TABLE statement to modify tables, including adding/dropping columns, renaming tables/columns, and changing column data types.

How do I configure SSL/TLS encryption for MySQL connections? How do I configure SSL/TLS encryption for MySQL connections? Mar 18, 2025 pm 12:01 PM

Article discusses configuring SSL/TLS encryption for MySQL, including certificate generation and verification. Main issue is using self-signed certificates' security implications.[Character count: 159]

How do you handle large datasets in MySQL? How do you handle large datasets in MySQL? Mar 21, 2025 pm 12:15 PM

Article discusses strategies for handling large datasets in MySQL, including partitioning, sharding, indexing, and query optimization.

What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)? What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)? Mar 21, 2025 pm 06:28 PM

Article discusses popular MySQL GUI tools like MySQL Workbench and phpMyAdmin, comparing their features and suitability for beginners and advanced users.[159 characters]

How do you drop a table in MySQL using the DROP TABLE statement? How do you drop a table in MySQL using the DROP TABLE statement? Mar 19, 2025 pm 03:52 PM

The article discusses dropping tables in MySQL using the DROP TABLE statement, emphasizing precautions and risks. It highlights that the action is irreversible without backups, detailing recovery methods and potential production environment hazards.

How do you represent relationships using foreign keys? How do you represent relationships using foreign keys? Mar 19, 2025 pm 03:48 PM

Article discusses using foreign keys to represent relationships in databases, focusing on best practices, data integrity, and common pitfalls to avoid.

How do you create indexes on JSON columns? How do you create indexes on JSON columns? Mar 21, 2025 pm 12:13 PM

The article discusses creating indexes on JSON columns in various databases like PostgreSQL, MySQL, and MongoDB to enhance query performance. It explains the syntax and benefits of indexing specific JSON paths, and lists supported database systems.

How do I secure MySQL against common vulnerabilities (SQL injection, brute-force attacks)? How do I secure MySQL against common vulnerabilities (SQL injection, brute-force attacks)? Mar 18, 2025 pm 12:00 PM

Article discusses securing MySQL against SQL injection and brute-force attacks using prepared statements, input validation, and strong password policies.(159 characters)

See all articles