导航:首页 > 源码编译 > 存储过程编译两次才成功

存储过程编译两次才成功

发布时间:2024-07-02 06:23:51

A. 为什么存储过程执行速度比普通的SQL快而且减少网络流量

存储过程所以快是因为他是预先编译的,当然节省了编译的时间。减少网络流量是指减少与客户端之间的交互,在服务器上执行运算,最后只把结果反给客户端,所以流量少。

比如你查询个内容,需要先查一个表,根据结果再查另外一个表。不用存储过程你怎么做呢?自然是先读出那个表的内容来,然后在asp/asp.net/php里,用代码生成一个语句再去查询,这样要往复2,3次。而用存储过程就可以直接在服务器上运算,只要一次来回就ok了,自然网络流量就减少

因为在存储过程中的SQL语句是已经经过了语法检查和编译的,可以直接执行;而SQL总要先进行语法解析和编译才能执行。另外对于网络执行的话,执行相同的任务,客户端调用存储过程的代码传输量和直接执行SQL语句相比也要更少。

B. 如何编写存储过程

//创建存储过程

CREATE PROCEDURE userData(

IN id INT

)

BEGIN

SELECT * from userdata WHERE userflag = id;

END;

其中IN是传进去的变量;

drop procere userData;//销毁这个存储过程。

call userData(2) //调用存储过程。

(2)存储过程编译两次才成功扩展阅读:

sql中的存储过程及相关介绍:

CREATE PROCEDURE [拥有者.]存储过程名[;程序编号]

[(参数#1,…参数#1024)]

[WITH

{RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION}

]

[FOR REPLICATION]

AS 程序行

其中存储过程名不能超过128个字。每个存储过程中最多设定1024个参数

(SQL Server 7.0以上版本),参数的使用方法如下:

@参数名数据类型[VARYING] [=内定值] [OUTPUT]。

每个参数名前要有一个“@”符号,每一个存储过程的参数仅为该程序内部使用,参数的类型除了IMAGE外,其他SQL Server所支持的数据类型都可使用。

[内定值]相当于我们在建立数据库时设定一个字段的默认值,这里是为这个参数设定默认值。[OUTPUT]是用来指定该参数是既有输入又有输出值的,也就是在调用了这个存储过程时,如果所指定的参数值是我们需要输入的参数。

同时也需要在结果中输出的,则该项必须为OUTPUT,而如果只是做输出参数用,可以用CURSOR,同时在使用该参数时,必须指定VARYING和OUTPUT这两个语句。

参考资料来源:网络-储存过程



阅读全文

与存储过程编译两次才成功相关的资料

热点内容
小米k30怎么创建文件夹 浏览:383
2355解压软件 浏览:817
php有多线程吗 浏览:446
程序员的七 浏览:284
淘宝app的主页为什么是灰色的 浏览:885
安卓手机怎么给抖音升级 浏览:594
matlab图形命令 浏览:927
app中国国税发票哪里转发 浏览:522
usb给单片机充电电路 浏览:445
java删除上传 浏览:748
泉城办app如何办理房产证 浏览:794
android动态改变高度 浏览:88
spss命令 浏览:491
云终端服务器连接 浏览:215
androidsqlite3加密 浏览:317
python判断二维数组 浏览:770
于右任标准草书pdf 浏览:384
哪里下载素材库app 浏览:648
pc控制单片机 浏览:543
php并发多少 浏览:574