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

存储过程编译两次才成功

发布时间: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这两个语句。

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



阅读全文

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

热点内容
py文件夹后缀 浏览:716
你对我们的app有什么建议 浏览:577
phpgetcookie 浏览:138
程序员最烦遇到的单词 浏览:122
开始服务器升级需要什么 浏览:979
gcc中的编译选项 浏览:188
程序员长沙开滴滴 浏览:136
十几加几的进位加法算法 浏览:384
c语言实现字母加密成字母 浏览:328
linux重启java服务 浏览:53
ubuntu的命令行在哪里 浏览:981
服务器tk是什么意思 浏览:397
防止软件加密码卸载 浏览:182
自建服务器与云服务器 浏览:542
已解压车能过户能买吗 浏览:775
上网行为linux 浏览:353
解压对身体的好处 浏览:72
php服务端框架 浏览:455
gitlabpdf 浏览:612
大专程序员面试公司 浏览:950