pgsql的存储过程调用mysql_postgresql 存储过程简单使用

本文介绍了如何在PostgreSQL中创建和使用存储过程,特别是如何调用MySQL的存储过程。详细讲解了存储过程的结构、变量类型、时间数据类型、控制结构,并给出了示例代码,包括批量插入数据的存储过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近写一些mysql的存储过程和函数,发现网上比较有价值的文档很少,大都是照着手册上抄来的,有些实际问题解决不了,比如用变量作表名。 经过反复调试,总算找到解决办法,一下是一些简单的记录,比较零碎。部分内容转自http://my.opera.com/Dereky/blog/show

一、存储过程结构:

Create or replace function 过程名(参数名 参数类型,…..) returns 返回值类型 as

$body$

//声明变量

Declare

变量名变量类型;

如:

flag Boolean;

变量赋值方式(变量名类型 :=值;)

如:

str  text :=值; / str  text;  str :=值;

Begin

函数体;

return 变量名; //存储过程中的返回语句

End;

$body$

Language plpgsql;

二、变量类型 :

除了postgresql内置的变量类型外,常用的还有 RECORD ,表示一条记录。

整数数据类型:

子类型

标准名

描述

Smalll integer

Smallint

一个2字节的符号型整数,可以存储-32768到32767的数字

Integer

Int

一个4字节的符号型整数,可以存储-2147483648到2147473647的数字

Serial

和integer一样,除了它的值通常是由PostgreSQL自动输入的。

浮点数据类型:(浮点数据也可以再细分,分为提供通用功能的浮点值和固定精度的数字)

子类型

标准名

描述

float

float(n)

支持最少精度为n,存储为最多8字节的浮点数。

float8

real

双精度(8字节)浮点数字

numeric

numeric(p,s)

拥有p个数字的实数,其中小数点后有s位。不像float,这始终是一个确切的数字,但工作效率比普通浮点数字低。

money

numeric(9,2)

PostgreSQL特有的类型,但在其他数据库里也普遍存在。Money类型从PostgreSQL 8.0开始不赞成使用,且可能在以后版本中取消。你应该使用number类型代替。

注࿱

### 回答1: MySQLPostgreSQL存储过程语法有一些不同。 MySQL存储过程语法使用 BEGIN 和 END 来定义存储过程的开始和结束,并使用 DECLARE 来定义变量。另外,MySQL 使用 CALL 来执行存储过程PostgreSQL存储过程语法使用 CREATE FUNCTION 来创建存储过程,并使用 $n 来定义变量。另外,PostgreSQL 使用 SELECT 或 PERFORM 来执行存储过程。 举个例子: MySQL: ``` DELIMITER // CREATE PROCEDURE test_procedure() BEGIN SELECT 'Hello, World!'; END // DELIMITER ; ``` PostgreSQL: ``` CREATE OR REPLACE FUNCTION test_procedure() RETURNS text AS $$ BEGIN RETURN 'Hello, World!'; END; $$ LANGUAGE plpgsql; ``` 总的来说,MySQLPostgreSQL存储过程语法上有一些差异,但大体上都是类似的。 ### 回答2: MySQLPostgreSQL是两个常用的关系型数据库管理系统,它们在存储过程编写的语法上存在一些区别。 首先,在MySQL中,存储过程使用的语法是类似于标准的SQL语法的。存储过程通常由BEGIN和END语句包围,并使用DELIMITER语句定义语句的分隔符。在存储过程中,可以使用IF、LOOP和BEGIN/END等控制结构,以及声明变量和使用游标等功能。MySQL存储过程的定义可以包含输入、输出以及输入输出参数。 而在PostgreSQL中,存储过程的语法更加接近于PL/pgSQL语言。存储过程的定义使用CREATE FUNCTION语句,并使用LANGUAGE指定为plpgsql。在存储过程中,可以使用IF、FOR循环、WHILE循环等控制结构,以及声明变量和使用游标等功能。与MySQL不同的是,PostgreSQL存储过程的定义可以包含输入、输出以及输入输出参数,还可以定义返回类型。 此外,MySQLPostgreSQL存储过程的异常处理上也存在差异。在MySQL中,可以使用DECLARE HANDLER语句来处理异常,当异常发生时会执行相应的操作。而在PostgreSQL中,使用EXCEPTION子句可以捕获异常,并通过使用RAISE语句来引发异常。 总的来说,虽然MySQLPostgreSQL存储过程的语法上有些许不同,但它们都能够实现类似的功能,例如封装复杂的逻辑、提高数据库性能和可维护性等。根据具体的需求和使用习惯,选择适合自己的数据库管理系统以及存储过程的编写语法是很重要的。 ### 回答3: MySQLPostgreSQL都是常用的关系型数据库管理系统之一,它们的存储过程编写语法有一些区别。 首先,MySQL存储过程编写语法相对简单。在MySQL中,使用DELIMITER语句来定义自定义分隔符,以区分语句块中的多个语句。存储过程定义以CREATE PROCEDURE语句开始,后跟存储过程名字、参数列表和BEGIN-END语句块,其中可以包含一系列的SQL语句和流程控制语句,最后以END结束。MySQL还允许使用DECLARE语句定义局部变量。 而PostgreSQL存储过程编写语法相对复杂一些。在PostgreSQL中,存储过程定义以CREATE OR REPLACE FUNCTION语句开始,后跟函数名、参数列表和返回值类型。存储过程的主体由$$和$$之间的代码块定义,可以包含多个SQL语句和流程控制语句。与MySQL不同的是,PostgreSQL使用DO语句块来定义匿名存储过程,它可以在不创建函数的情况下直接执行一段代码。 此外,MySQLPostgreSQL存储过程的特性上也有一些区别。MySQL存储过程不支持递归调用和异常处理,而PostgreSQL支持这些功能。此外,PostgreSQL还提供了丰富的内置函数和扩展函数,使得编写复杂的存储过程更加灵活和强大。 综上所述,MySQLPostgreSQL存储过程编写语法在语法结构和特性上存在一些区别。熟悉这些区别,开发人员可以根据不同的需求选择合适的数据库管理系统和存储过程编写方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值