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,是因为我不知道如何让函数不返回值。等待改进。