国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > PostgreSQL > 正文

PostgreSQL7.0手冊-用戶手冊-12. PL/perl - Perl 過程語言

2019-09-08 23:33:09
字體:
來源:轉載
供稿:網友
第十二章. PL/perl - Perl 過程語言
內容 
概述 
制做和安裝 
使用 PL/Perl 
本章描述如何編譯,安裝和使用 PL/Perl. 
概述
PL/Perl 允許你用 Perl 腳本語言書寫可以用于 SQL 查詢的函數,就好象它們是內建在 Postgres 里一樣. 
PL/Perl 解釋器是一個完整的 Perl 解釋器.不過,有些操作出于安全性的考慮被屏蔽掉了. 

通常,被限制的操作是那些于環境交互的動作.包括文件句柄操作,請求和使用(對于外部模塊而言). 

要知道,安全不是絕對的.實際上,有幾種拒絕服務攻擊仍然是可能的-存儲器耗盡和無限循環就是兩個例子. 


--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

制作和安裝
假設 Postgres 源代碼樹的根是 $PGSRC,那么 Pl/perl 源代碼位于 $PGSRC/src/pl/plperl. 
要制作,只需要按照下面步驟處理: 

cd $PGSRC/src/pl/plperl
perl Makefile.PL
make
這樣做將創建共享庫文件.在一個 Linux 系統里,它將被叫做 plperl.so.在其他系統里的擴展名可能不同. 
然后應該把該共享庫拷貝到 postgres 安裝的 lib 子目錄下. 

createlang 命令用于將該語言安裝到一個數據庫中.如果它被安裝到 template1 里面,以后創建的所有數據庫將自動安裝這個語言.


--------------------------------------------------------------------------------
--------------------------------------------------------------------------------

使用 PL/Perl
假設你有下面的表: 
CREATE TABLE EMPLOYEE (
    name text,
    basesalary int4,
    bonus int4 );
為了獲取所有的薪水(本金+獎勵),我們將定義下面這樣的函數: 
CREATE FUNCTION totalcomp(int4, int4) RETURNS int4
    AS 'return $_[0] + $_[1]'
    LANGUAGE 'plperl';
請注意參數會象想象的那樣以 @_ 形式傳遞給函數.還有,因為 SQL 創建函數的引號規則,你會發現你要比平常更頻繁地使用擴展的引號函數(qq[],q[],qw[]). 
我們現在可以象下面這樣使用我們的函數. 

SELECT name, totalcomp(basesalary, bonus) from employee
不過,我們還可以把我們的整個記錄傳遞個我們的函數: 
CREATE FUNCTION empcomp(employee) returns int4
    AS 'my $emp = shift;
        return $emp->{'basesalary'} + $emp->{'bonus'};'
    LANGUAGE 'plperl';
記錄是作為一個散列(哈?!ash)數組的引用傳遞的.腳標是記錄里面的字段名稱.值是記錄里面對應的字段的值. 
新函數 empcomp 可以這樣使用: 

SELECT name, empcomp(employee) from employee;

--------------------------------------------------------------------------------
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 安宁市| 汕头市| 南城县| 桃园县| 青神县| 连云港市| 永济市| 琼海市| 启东市| 秦安县| 遵化市| 出国| 丹江口市| 崇左市| 平度市| 冀州市| 永平县| 将乐县| 阳泉市| 仁化县| 宾川县| 清河县| 弥勒县| 卓资县| 乐山市| 安康市| 太仓市| 永修县| 平原县| 博野县| 延川县| 安多县| 高雄市| 唐海县| 沙湾县| 慈利县| 阿克苏市| 上饶市| 上饶市| 新沂市| 古田县|