MySql编写一个存储过程?

MySql编写一个存储过程?,第1张

1、delimiter // ,声明分隔符:DELIMITER是分割符的意思,因为MySQL默认以""为分隔符,如果我们没有声明分割符,那么编译器会把存储过程当成SQL语句进行处理,则存储过程的编译过程会报错,所以要事先用DELIMITER关键字申明当前段分隔符,这样MySQL才会将""当做存储过程中的代码,不会执行这些代码(这里如果不懂的话,你可以通过试错的方法来理解)。2、编写存储过程的格式:CREATE PROCEDURE([[IN |OUT |INOUT ]参数名数据类形...])例子:1)create procedure proc1(out s int) // 只有输出2)create procedure proc2(in p_in bigint) // 只有输入3)create procedure proc15() // 没有输入与输出4)create procedure demo_multi_param(in id bigint,in name varchar(32),out c int) //多输入与输出3、过程体的开始与结束使用BEGIN与END进行标识。4、select count (*) into s from student// 过程体,一系列的逻辑语句,sql语句5、delimiter 用完了之后要把分隔符还原。

在MySQL中如何创建一个带输出参数为一个表类型的存储过程

首先需要知道“另一个存储过程”的结果集的所有列的类型。

假设“另一个存储过程”的名字是

sp1

,没有参数,返回的结果集共3列,全部为int型,那么“存储过程”里添加一个与结果集列数相同的临时表或表变量用于接收“另一个存储过程”的结果集

如下

CREATE

PROCEDURE

sp2

AS

DECLARE

@t

table(a

int,b

int,c

int)

INSERT

INTO

@t(a,b,c)

EXEC

sp1

SELECT

*

FROM

@t

使用

SQLSERVER

存储过程可以很大的提高程序运行速度,简化编程维护难度,现已得到广泛应用。

创建存储过程

和数据表一样,在使用之前需要创建存储过程,它的简明语法是:

引用:

Create

PROC

存储过程名称

[参数列表(多个以“,”分隔)]

AS

SQL

语句

例:

引用:

Create

PROC

upGetUserName

@intUserId

INT,

@ostrUserName

NVARCHAR(20)

OUTPUT

--

要输出的参数

AS

BEGIN

--

将uName的值赋给

@ostrUserName

变量,即要输出的参数

Select

@ostrUserName=uName

FROM

uUser

Where

uId=@intUserId

END

其中

Create

PROC

语句(完整语句为Create

PROCEDURE)的意思就是告诉SQL

SERVER,现在需要建立一个存储过程,upGetUserName

就是存储过程名称,@intUserId

@ostrUserName

分别是该存储过程的两个参数,注意,在SQL

SERVER中,所有用户定义的变量都以“@”开头,OUTPUT关键字表示这个参数是用来输出的,AS之后就是存储过程内容了。只要将以上代码在“查询分析器”里执行一次,SQL

SERVER就会在当前数据库中创建一个名为“upGetUserName”的存储过程。你可以打开“企业管理器”,选择当前 *** 作的数据库,然后在左边的树型列表中选择“存储过程”,此时就可以在右边的列表中看到你刚刚创建的存储过程了(如果没有,刷新一下即可)。

二、存储过程的调用

之前已经创建了一个名为“upGetUserName”的存储过程,从字面理解该存储过程的功能是用来取得某一个用户的名称。存储过程建立好了,接下来就是要在应用程序里调用了,下面看一下在ASP程序里的调用。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5900849.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-07
下一篇 2023-03-07

发表评论

登录后才能评论

评论列表(0条)

保存