Pg列式存儲
❶ 我想導出pg資料庫中的所有存儲過程,每個存儲過程一個文件,文件名就是存儲過程的名字。可以實現嗎感謝
需要存儲過程實現。
1、創建輸出路徑,比如你要在d盤test目錄下輸出,你就先在d盤根目錄下建立一個test的目錄。
2、sqlplus下以sysdba登錄,執行以下語句
12345createorreplacedirectoryTMPas'd: est';grantread,writeondirectoryTMPtoscott;--比如我用的scott用戶altersystemsetutl_file_dir='d: est'scope=spfile;
3、以上步驟執行完,需要重啟資料庫。
4、創建一個存儲過程,代碼如下(基本是不用改動,原封復制即可):
CREATEORREPLACEPROCEDURESP_OUTPUT_PROCEDUREisfile_handleutl_file.file_type;Write_contentVARCHAR2(1024);Write_file_nameVARCHAR2(50);v_namevarchar2(50);v_textvarchar2(2000);cursorcur_procere__sourcewheretype='PROCEDURE';cursorcur_sp_outisselectt.textfrom(select0line,'CREATEORREPLACE'textfromalunionselectline,textfromuser_sourcewheretype='PROCEDURE'andname=v_name)torderbyline;beginopencur_procere_name;loopfetchcur_procere_nameintov_name;exitwhencur_procere_name%notfound;write_file_name:=v_name||'.txt';opencur_sp_out;loopfetchcur_sp_outintov_text;exitwhencur_sp_out%notfound;file_handle:=utl_file.fopen('TMP',write_file_name,'a');write_content:=v_text;--writefileIFutl_file.is_open(file_handle)THENutl_file.put_line(file_handle,write_content);ENDIF;--closefileutl_file.fclose(file_handle);endloop;closecur_sp_out;endloop;closecur_procere_name;end;
5、創建完畢執行存儲過程,這個就不贅述了,執行完畢後,你會發現d盤test目錄下的文件名就是以存儲過程名命名的txt文件,如圖:
❷ postgresql存儲過程 怎麼實現無返回值
PostgreSQL 存儲過程定義格式如下:
■結構 PL/pgSQL是一種塊結構的語言,比較方便的是用pgAdmin III新建Function,填入一些參數就可以了。
基本上是這樣的:
CREATE OR REPLACE FUNCTION 函數名(參數1,[整型 int4, 整型數組 _int4, ...]) RETURNS 返回值類型 AS $BODY$ DECLARE 變數聲明 BEGIN 函數體 END; $BODY$ LANGUAGE 『plpgsql』 VOLATILE;
■變數類型 除了postgresql內置的變數類型外,常用的還有 RECORD ,表示一條記錄。
■賦值 賦值和Pascal有點像:「變數 := 表達式;」 有些奇怪的是連接字元串的是「||」,比如 sql := 『SELECT * FROM』 || table || 『WHERE …』;
■判斷 判斷又和VB有些像: IF 條件 THEN … ELSEIF 條件 THEN … ELSE … END IF;
■循環 循環有好幾種寫法: WHILE expression LOOP statements END LOOP; 還有常用的一種是:(從1循環到9可以寫成FOR i IN 1..9 LOOP) FOR name IN [ REVERSE ] expression .. expression LOOP statements END LOOP;
■其他 還有幾個常用的函數: SELECT INTO record …; 表示將select的結果賦給record變數(RECORD類型) PERFORM query; 表示執行query並丟棄結果 EXECUTE sql; 表示執行sql語句,這條可以動態執行sql語句(特別是由參數傳入構造sql語句的時候特別有用)
--簡單的例子:
例1:無返回值
CREATE OR REPLACE FUNCTION 函數名稱( 參數1,參數2,...)
AS
$BODY$
DECLARE --定義
BEGIN
INSERT INTO "表名" VALUES(參數1,參數2,...);
END
$BODY$
LANGUAGE 'plpgsql' VOLATILE; -- 最後別忘了這個。
例2:有返回值
CREATE OR REPLACE FUNCTION 函數名稱(deptcode VARCHAR(20) ,deptname VARCHAR(60) ,pycode VARCHAR(60),isenabled CHAR(1))
RETURNS BOOLEAN --返回值,布爾類型
AS
$body$
DECLARE
deptcode VARCHAR(20);
deptname VARCHAR(60);
pycode VARCHAR(60);
isenabled CHAR(1);
BEGIN
UPDATE "deptDict" SET deptcode=deptcode,deptname=deptname,pycode=pycode,isenabled=isenabled,updatedhisdatetime=CURRENT_TIMESTAMP
WHERE deptcode=deptcode;
RETURN TRUE;
END
$body$
LANGUAGE 'plpgsql' VOLATILE;
最後再加上如何執行這個存儲過程(函數)
-- 執行存儲過程方法1
SELECT * FROM 函數名稱(參數1,參數2,...)
-- 執行存儲過程方法2
SELECT 函數名稱('0參數1,參數2,...)
❸ PG資料庫存儲過程包含存儲過程報語法錯誤,麻煩大神看看是什麼問題
--改成這樣 你的insert語法有問題 你可以顯示出來看看
alter PROCEDURE [dbo].[LP_TABLE_1]
( @Name VARCHAR(20))
AS
BEGIN
DECLARE @sqlStr NVARCHAR(2000);
SET @sqlStr = 'INSERT INTO Table_1 (name) VALUES ('+'''' + @Name + ''''+')'
EXECUTE (@sqlStr)
--print (@sqlStr)
END
❹ pg庫正則走索引嗎
是的
PG索引類型
CREATE INDEX 在一個指定表或者物化視圖的指定列上創建一個索引,索引主要用來提高資料庫的效率(盡管不合理的使用將導致較慢的效率)選擇性越好(唯一值個數接近記錄數)的列,越適合b-tree。當被索引列存儲相關性越接近1或-1時,數據存儲越有序,范圍查詢掃描的HEAP PAGE越少。支持多列索引,默認最多32列,編譯可改。(通過調整pg_config_manual.h可以做到更大,但是還有另一個限制,indextuple不能超過約1/4的數據塊(索引頁)大小,也就是說復合索引列很多的情況下,可能會觸發這個限制)
❺ 怎樣將正在播放的MPG格式文件存儲成為pg格式
1\按ctrl+r,輸入cmd,按enter,輸入rename 文件名.mpg 文件名.pg,回車。
2\打開「我的電腦」,點「工具菜單」「文件夾選項」「查看」去掉「隱藏已知文件類型的擴展名」前的對號,確定,右鍵選擇要改名的文件,重命名,改成pg的就行了。
3\拿超級解霸,或者media player 把文件另存一些,變成pg格式的就行了,
順便問問,pg是什麼文件格式?pg是蘋果的縮寫嗎?
❻ pg一張表在不影響頻繁的訪問性能情況下,最多能存儲多少條數據
按照上面的理論,那麼我們計算一下bigint為主鍵表的最大理論行數
公式1 : (16KB -200) / 8 = 2023 行
公式2 : 當然,也可以這么算:(16KB)/8 - 200 = 1848行
因為mysql最高的索引樹為三層(表為第一層),那行最大的行數應該為 2023 * 2023= 4092529 行 或 1848 * 1848 = 3415104 行
因為筆者自己也沒有本身測試過,都只是五百萬行一分表,聽圈裡人都說500W是經驗值所以筆者也就沒有深入的去研究過了。等筆者有時間空了,好好的測試一下,呵呵~
❼ postgresql存儲過程怎麼用
PostgreSQL有pldbgapi擴展,先安裝此擴展。
首先,需要將debug的模組載入到PostgreSQL伺服器中去。做法是: 在pgAdminIII中以管理員登錄,然後選擇菜單「工具->伺服器配置->postgresql.conf」,
在配置窗口中,雙擊項目"shared_preload_libraries",
在其設定窗口中,將值設置成plugin_debugger的路徑(Windows 9.3版本的為$libdir/plugin_debugger.dll, $libdir一般為PostgreSQL安裝目錄下的lib文件夾)。非Windows系統的後綴名會有所不同,可能為plugin_debugger.so。
注意,在做這一步時最好先備份配置文件,以防指定文件找不到而導致伺服器不能啟動。
在設定完成之後,重新啟動PostgreSQL服務(以啟動debug插件)。
然後在pgAdminIII中擴展安裝時選擇如下圖項目,
這樣在函數的右鍵菜單中就有調試選項了,
當然,最常用的調試方式就是自己直接調用函數來查看執行結果是否正確。
❽ 西門子PLC裡面所說的PG是什麼意思
PG/PC就是編程設備/個人計算機。
編程器為可編程的集成電路寫入數據的工具,編程器主要用於單片機(含嵌入式)/存儲器(含BIOS)之類的晶元的編程(或稱刷寫)。編程器主要修改只讀存儲器中的程序,編程器通常與計算機連接,再配合編程軟體使用。
多功能編程器:支持AT89系列晶元、AVR晶元、EPROM、EEPROM、FLASH和串列EEPROM系列晶元,常用的PIC單片機晶元;價格較低,性價比很高;既適合於汽車電子和電腦愛好者使用,也適合於電子電腦維修人員和單片機開發人員使用。
(8)Pg列式存儲擴展閱讀:
編程器通過數據線與計算機並口(列印機介面)聯接,獨立的外接電源,使用操作更方便,編程更穩定;採用 WINDOWS下的圖形界面,使用滑鼠進行操作,支持 Windows ME/98/95/2000系統,具有編程指示,控製程序工作界面友好,對晶元的各種操作變得十分簡單。
多功能編程器:支持AT89系列晶元、AVR晶元、EPROM、EEPROM、FLASH和串列EEPROM系列晶元,常用的PIC單片機晶元;價格較低,性價比很高;既適合於汽車電子和電腦愛好者使用,也適合於電子電腦維修人員和單片機開發人員使用。
不用添加適配器就可以支持200多種器件,在添加適配器後,可以支持51系列單片機的全系列型號,和最新的大容量程序晶元!支持3.3V及2.9V電壓的晶元。使用FWH(PLCC32)轉換座,可以支持最新Intel810、815、845主板上使用的N82802AB、SST49LF002、SST49LF004等3.3V電壓的晶元。
❾ postgresql 存儲過程的事務處理
一個PostgreSQL存儲過程的例子
需求:
給出如下條件進行批處理編排
- 開始日期時間
- 重復間隔(分鍾)
- 重復次數
要求在檔期內重復安排節目播出, 比如: 2003.01.01 08:00 開始每隔240分鍾播出一次, 一共播出100次
資料庫表格(CO_SCHEDULE)
------------------------------
N_PROGID INT
DT_STARTTIME TIMESTAMP
DT_ENDTIME TIMESTAMP
存儲過程的實現:
create table co_schele(n_progid int,dt_starttime timestamp,dt_endtime timestamp);
//創建函數:
create function add_program_time(int4,timestamp,int4,int4,int4) returns bool as '
declare
prog_id alias for $1;
ration_min alias for $3;
period_min alias for $4;
repeat_times alias for $5;
i int;
starttime timestamp;
ins_starttime timestamp;
ins_endtime timestamp;
begin
starttime :=$2;
i := 0;
while i<repeat_times loop
ins_starttime := starttime;
ins_endtime := timestamp_pl_span(ins_starttime,ration_min || ''mins'');
starttime := timestamp_pl_span(ins_starttime,period_min || ''mins'');
insert into co_schele values(prog_id,ins_starttime,ins_endtime);
i := i+1;
end loop;
if i<repeat_times then
return false;
else
return true;
end if;
end;
'language 'plpgsql';
//執行函數:
select add_program_time(1,'2002-10-20 0:0:0','5','60','5');
//查看結果:select * from co_schele;
n_progid | dt_starttime | dt_endtime
----------+------------------------+------------------------
1 | 2002-10-20 00:00:00+08 | 2002-10-20 00:05:00+08
1 | 2002-10-20 01:00:00+08 | 2002-10-20 01:05:00+08
1 | 2002-10-20 02:00:00+08 | 2002-10-20 02:05:00+08
1 | 2002-10-20 03:00:00+08 | 2002-10-20 03:05:00+08
1 | 2002-10-20 04:00:00+08 | 2002-10-20 04:05:00+08
ps:
1.資料庫一載入 plpgsql語言。如沒有,
su - postgres
createlang plpgsql dbname
2.至於返回類型為bool,是因為我不知道如何讓函數不返回值。等待改進。