亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PostgreSQL數(shù)據庫中匿名塊的寫法實例

 更新時間:2021年01月07日 09:44:09   作者:msdnchina  
這篇文章主要介紹了PostgreSQL數(shù)據庫中匿名塊的寫法實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

看代碼吧~

test=# DO $$DECLARE i record;
test$# BEGIN
test$# FOR i IN 1..10
test$# LOOP 
test$# execute 'select loop_insert(1)';
test$# END LOOP;
test$# END$$;
DO
test=# 

看匿名塊的執(zhí)行效果:

test=# select count(*) from lineitem;
 count 
-------
 7000
(1 row) 
test=# select count(*) from lineitem;
 count 
-------
 17000 ------------->>>>匿名塊插入了10000條記錄.
(1 row) 
test=# 

補充:PostgreSql 的PL/pgSQL 塊結構 (在pgAdmin查詢工具中如何執(zhí)行語句塊)

PostgreSql 的PL/pgSQL 塊結構

本文我們學習PL/pgSQL結構塊,包括如何寫結構塊和執(zhí)行結構塊。

什么是結構塊

PL/pgSQL是結構塊語言,因此,PL/pgSQL函數(shù)或過程是通過結構塊進行組織。完整結構塊的語法如下:

[ <<label>> ]
[ DECLARE
 declarations ]
BEGIN
 statements;
 ...
END [ label ];

詳細說明如下:

塊有兩部分組成:聲明部分和主體部分。聲明部分是可選的,而主體部分是必須的。塊在end關鍵字后面使用分號(;)表示結束。

塊可以有個可選的標簽在開始和結尾處。如果你想在塊主體中使用exit語句或限定塊中聲明的變量名稱時,需要使用塊標簽。

主體部分是編寫代碼的地方,每條語句需要使用分號結束。

PL/pgSQL 塊結構示例

下面示例描述一個簡單塊結構,一般稱為匿名塊:

DO $$
<<first_block>>
DECLARE
 counter integer := 0;
BEGIN
 counter := counter + 1;
 RAISE NOTICE 'The current value of counter is %', counter;
END first_block $$;

運行結果:

NOTICE: The current value of counter is 1 

從pgAdmin中執(zhí)行塊,點擊圖示按鈕:

注意DO語句不屬于塊結構。它用于執(zhí)行匿名塊。PostgreSQL 在9.0版本中引入DO語句。

在聲明部分定義變量counter并設置為0.

在主體部分,是counter值加1,通過RAISE NOTICE語句輸出其值。

first_block 標簽僅為了演示需要,本例中沒有啥意義。

** 什么是雙 ($$) 符號?**

($$) 符號 是單引號(')的替代符號。開發(fā)PL/pgSQL 時,無論是函數(shù)或過程,必須把主體部分放在一個字符串中。因此必須對主體部分的單引號進行轉義表示:

DO
'<<first_block>>
DECLARE
 counter integer := 0;
BEGIN 
 
 counter := counter + 1;
 RAISE NOTICE ''The current value of counter is %'', counter; 
END first_block';

使用($$) 符號可以避免引號問題。也可以在$之間使用標識,如之間使用標識,如之間使用標識,如function$ , procedureprocedureprocedure.

PL/pgSQL 子結構塊

PL/pgSQL可以一個塊在另一個塊的主體中。一個塊嵌入在另一個塊中稱為子塊,包含子塊的塊稱為外部塊。

子塊用于組織語句,這樣大塊能被分為更小和更多邏輯子塊。子塊的變量的名稱可以與外部塊變量名稱同名,雖然這在實踐中不建議。當在子塊中聲明一個與外部變量同名的變量,外部變量在子塊中被隱藏。如果需要訪問外部塊的變量,可以使用塊標簽作為變量的限定符,如下面示例:

DO $$ 
<<outer_block>>
DECLARE
 counter integer := 0;
BEGIN 
 counter := counter + 1;
 RAISE NOTICE 'The current value of counter is %', counter;
 
 DECLARE 
 counter integer := 0;
 BEGIN 
 counter := counter + 10;
 RAISE NOTICE 'The current value of counter in the subblock is %', counter;
 RAISE NOTICE 'The current value of counter in the outer block is %', outer_block.counter;
 END;
 
 RAISE NOTICE 'The current value of counter in the outer block is %', counter;

執(zhí)行結果如下:

NOTICE: The current value of counter is 1
NOTICE: The current value of counter in the subblock is 10
NOTICE: The current value of counter in the outer block is 1
NOTICE: The current value of counter in the outer block is 1

首先,在外部塊中聲明變量counter。

接著在子塊中也聲明了一個同名變量。

在進入子塊之前,變量的值為1。在子塊中,我們給變量counter值加10,然后打印出來。注意,這個改變僅影響子塊中counter變量。

然后,我們通過標簽限定符引用外部變量:outer_block.counter

最后,我們打印外部塊變量,其值保持不變。

總結

本文我們學習PL/pgSQL塊結構,通過DO語句可以執(zhí)行匿名塊。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關文章

  • PostgreSql觸發(fā)器創(chuàng)建、使用以及刪除示例詳解

    PostgreSql觸發(fā)器創(chuàng)建、使用以及刪除示例詳解

    在PostgreSQL中觸發(fā)器函數(shù)是一個沒有參數(shù)并且返回trigger類型的函數(shù),這篇文章主要給大家介紹了關于PostgreSql觸發(fā)器創(chuàng)建、使用以及刪除的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-03-03
  • 使用psql操作PostgreSQL數(shù)據庫命令詳解

    使用psql操作PostgreSQL數(shù)據庫命令詳解

    這篇文章主要為大家介紹了使用psql操作PostgreSQL數(shù)據庫命令詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • 在windows下手動初始化PostgreSQL數(shù)據庫教程

    在windows下手動初始化PostgreSQL數(shù)據庫教程

    在windows下手動初始化PG,是一件比較麻煩的事,下面我具體寫一下過程,大家做一下參考。
    2014-09-09
  • PgSQL條件語句與循環(huán)語句示例代碼詳解

    PgSQL條件語句與循環(huán)語句示例代碼詳解

    這篇文章主要介紹了PgSQL條件語句與循環(huán)語句,pgSQL中有兩種條件語句分別為if與case語句,每種語句通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • 用PostgreSQL數(shù)據庫做地理位置app應用

    用PostgreSQL數(shù)據庫做地理位置app應用

    項目中用到了postgreSQL中的earthdistance()函數(shù)功能計算地球上兩點之間的距離,中文的資料太少了,我找到了一篇 英文的、講的很好的文章,特此翻譯,希望能夠幫助到以后用到earthdistance的同學
    2014-03-03
  • postgresql 實現(xiàn)數(shù)據的導入導出

    postgresql 實現(xiàn)數(shù)據的導入導出

    這篇文章主要介紹了postgresql 實現(xiàn)數(shù)據的導入導出,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • PostgreSQL字符切割:substring函數(shù)的用法說明

    PostgreSQL字符切割:substring函數(shù)的用法說明

    這篇文章主要介紹了PostgreSQL字符切割:substring函數(shù)的用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • Postgresql開啟遠程訪問的步驟全紀錄

    Postgresql開啟遠程訪問的步驟全紀錄

    postgre一般默認為本地連接,不支持遠程訪問,所以如果要開啟遠程訪問,需要更改安裝文件的配置。下面這篇文章主要給大家介紹了關于Postgresql開啟遠程訪問的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2018-03-03
  • PostgreSQL實時查看數(shù)據庫實例正在執(zhí)行的SQL語句實例詳解

    PostgreSQL實時查看數(shù)據庫實例正在執(zhí)行的SQL語句實例詳解

    在任何數(shù)據庫中,分析和優(yōu)化SQL的執(zhí)行,最重要的工作就是執(zhí)行計劃的解讀,而說到執(zhí)行計劃得先了解postgresql的查詢執(zhí)行過程,下面這篇文章主要給大家介紹了關于PostgreSQL實時查看數(shù)據庫實例正在執(zhí)行的SQL語句的相關資料,需要的朋友可以參考下
    2023-01-01
  • 如何解決PostgreSQL執(zhí)行語句長時間卡著不動不報錯也不執(zhí)行的問題

    如何解決PostgreSQL執(zhí)行語句長時間卡著不動不報錯也不執(zhí)行的問題

    某日開發(fā)同事上報一sql性能問題,一條查詢好似一直跑不出結果,查詢了n小時,還未返回結果,這篇文章主要給大家介紹了關于如何解決PostgreSQL執(zhí)行語句長時間卡著不動不報錯也不執(zhí)行問題的相關資料,需要的朋友可以參考下
    2024-02-02

最新評論