PL/SQL的游標

来源:https://www.cnblogs.com/dishengbai/archive/2018/04/23/8922424.html
-Advertisement-
Play Games

使用變數並不能完全滿足SQL語句嚮應用程式輸出數據的要求的,一組變數只能存放一條記錄,而查詢結果的記錄數是不確定的,所以才有了游標的概念。 基本原理 在PL/SQL中執行select、insert、update和delete語句時,oracle會在記憶體中分配上下文區,即一個緩衝區。而游標就是指向該區 ...


  使用變數並不能完全滿足SQL語句嚮應用程式輸出數據的要求的,一組變數只能存放一條記錄,而查詢結果的記錄數是不確定的,所以才有了游標的概念。

基本原理

  在PL/SQL中執行select、insert、update和delete語句時,oracle會在記憶體中分配上下文區,即一個緩衝區。而游標就是指向該區的一個指針。

  游標分為顯式游標和隱式游標。

  顯式游標是由用戶聲明和操作的一種游標;

  隱式游標時Oracle為所有數據操縱語句自動聲明和操作的一種游標。

  在每個用戶會話中,可以同時打開多個游標,其數量是由資料庫初始化參數文件中的OPEN CURSOR參數定義。

顯式游標

  

1.聲明游標

  Cursor<游標名> is SELECT<語句>,游標必須在引用前被聲明,游標可以聲明在where子句中引用Pl/Sql變數,這些變數被認為是聯編變數,即已經被分配空間並映射到絕對地址的變數。

2.打開游標

  OPEN<游標名>

  打開游標執行select語句。執行完畢後,查詢結果存入記憶體,游標停在查詢結果的首部。

  當打可以一個游標時,會完成以下幾件事情。

    1)檢查聯編變數的取值

    2)根據聯編變數的取值,確定活動集。

    3)活動集的指針指向第一行

3.提取游標

  打開游標後的工作就是取值了,取值語句是fetch,用法如下:

  fetch<游標名> into <變數列表>或者fetch<游標名> into pl/sql記錄

fetch語句每執行一次,游標向後移動一行,直到結束(游標只能逐個向後移動,而不能跳躍移動或者向前移動)

4.關閉游標

  當所有的活動集都被檢索以後,游標就應該被關閉。pl/sql程式將被告知對於游標的處理已經結束,與游標相關聯的資源可以被釋放了。

  close<有標明>,游標關閉後不能從游標取數據了,會報如下錯誤:

 

 

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. Kafka 簡介 Kafka是一種分散式的,基於發佈/訂閱的消息系統,起源於 LinkedIn,用作 LinkedIn 的活動流和運營數據處理管道的基礎。它有以下一些性能特性: 能夠以 O(1) 的時間複雜度提供消息持久化能力,即使對 TB 級以上的數據也能保證常熟時間複雜度的訪問性能; 高吞 ...
  • 隨著雲伺服器的普及,購入雲伺服器的門檻越來越低,對一個程式員來說,很多人會購買一款雲伺服器。以前買過兩年windows伺服器(沒有什麼實際用途,就是為了玩),最近有機會接觸一下linux伺服器,選擇了系統為centos7的阿裡雲伺服器,下麵和大家一起來學習一下linux伺服器的各種操作(純新手)。 ...
  • 官方參考文檔:docs.ansible.com 第一講:ansible簡介及Iventory Ansible基本架構: Ansible基本組成: Ansible工作原理: Ansible安裝: 配置好epel源,yum install -y ansible ansible主要文件和命令: Ansib ...
  • 用ssh連其他linux機器,會等待10-30秒才有提示輸入密碼。嚴重影響工作效率。登錄很慢,登錄上去後速度正常,這種情況主要有兩種可能的原因: 1. DNS反向解析的問題 OpenSSH在用戶登錄的時候會驗證IP,它根據用戶的IP使用反向DNS找到主機名,再使用DNS找到IP地址,最後匹配一下登錄 ...
  • 寫作背景: 項目是基於java、weblogic及timer的處理模式,每次服務部署之後timer的整體狀態是一個盲區,因為100多個進程,是否有啟動遺漏或者啟動重覆的,想做到一目瞭然是件困難的事情。所以我考慮用shell腳本的文件查找與匹配方法來解決這個問題,簡單記錄下,僅供參考。 程式說明: 1 ...
  • 非常強大的文本操縱工具,sed,awk,grep 這個三個命令 都是操作文本文件的unix系統有幾個非常命令的特點:1. 對於內核而言,unix文件都是位元組序列。io設備也是文件。2. 至於文件的含義交由應用程式來解釋。其中文本文件非常重要,因為unix提供 很多了實用程式(utility),這些程 ...
  • 在VMware workstation12上新建虛擬機,發現無法連接網路。然後查了一些資料,知道了怎樣配置網路,記錄一下。 1、首先用ifconfig命令查看虛擬機的IP地址及網關信息 觀察顯示內容,查看虛擬機的網關名稱ens33是否有IP地址 2、如果沒有,使用vi /etc/sysconfig/ ...
  • 設計好處 良好的資料庫邏輯設計和物理設計師資料庫獲得高性能的基礎 範式化設計和反範式化設計(減少冗餘、減少異常、讓數據組織的更加和諧) 優化目的 減少數據冗餘(儘量) 儘量避免數據維護中出現更新、插入和刪除等異常 插入:如果表中的某個實體隨著另一個實體而存在 更新:如果更改表中的某個實體的單獨屬性時 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...