iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >数据库存储过程如何写
  • 404
分享到

数据库存储过程如何写

2024-04-02 19:04:59 404人浏览 薄情痞子
摘要

小编给大家分享一下数据库存储过程如何写,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!存储过程简介sql语句需要先编译然后执行,而

小编给大家分享一下数据库存储过程如何写,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

存储过程简介

sql语句需要先编译然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。存储过程是可编程的函数,在数据库中创建并保存,可以由SQL语句和控制结构组成。当想要在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的。数据库中的存储过程可以看做是对编程中面向对象方法的模拟,它允许控制数据的访问方式。

存储过程的优点:

(1).增强SQL语言的功能和灵活性:存储过程可以用控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。

(2).标准组件式编程:存储过程被创建后,可以在程序中被多次调用,而不必重新编写该存储过程的SQL语句。而且数据库专业人员可以随时对存储过程进行修改,对应用程序源代码毫无影响。

(3).较快的执行速度:如果某一操作包含大量的Transaction-SQL代码或分别被多次执行,那么存储过程要比批处理的执行速度快很多。因为存储过程是预编译的。在首次运行一个存储过程时查询,优化器对其进行分析优化,并且给出最终被存储在系统表中的执行计划。而批处理的Transaction-SQL语句在每次运行时都要进行编译和优化,速度相对要慢一些。

(4).减少网络流量:针对同一个数据库对象的操作(如查询、修改),如果这一操作所涉及的Transaction-SQL语句被组织进存储过程,那么当在客户计算机上调用该存储过程时,网络中传送的只是该调用语句,从而大大减少网络流量并降低了网络负载。

(5).作为一种安全机制来充分利用:通过对执行某一存储过程的权限进行限制,能够实现对相应的数据的访问权限的限制,避免了非授权用户对数据的访问,保证了数据的安全。

Mysql的存储过程

存储过程是数据库的一个重要的功能,mysql 5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣。好在MySQL 5.0开始支持存储过程,这样即可以大大提高数据库的处理速度,同时也可以提高数据库编程的灵活性。

MySQL存储过程的创建

语法

CREATE PROCEDURE  过程名([[IN|OUT|INOUT] 参数名 数据类型[,[IN|OUT|INOUT] 参数名 数据类型…]]) [特性 ...] 过程体
DELIMITER //  
  CREATE PROCEDURE myproc(OUT s int)    
    BEGIN     
     SELECT COUNT(*) INTO s FROM students;    
    END    
    //
DELIMITER ;

分隔符

MySQL默认以";"为分隔符,如果没有声明分割符,则编译器会把存储过程当成SQL语句进行处理,因此编译过程会报错,所以要事先用“DELIMITER //”声明当前段分隔符,让编译器把两个"//"之间的内容当做存储过程的代码,不会执行这些代码;“DELIMITER ;”的意为把分隔符还原。

参数

存储过程根据需要可能会有输入、输出、输入输出参数,如果有多个参数用","分割开。MySQL存储过程的参数用在存储过程的定义,共有三种参数类型,IN,OUT,INOUT:

IN参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值OUT:该值可在存储过程内部被改变,并可返回INOUT:调用时指定,并且可被改变和返回

过程体

过程体的开始与结束使用BEGIN与END进行标识。

总结

本次主要是掌握了对于存储过程的使用,总的来说,存储过程实际上类似于c++中的函数,而在C++中我们是需要在创建这一过程的文件中去调用这一函数,但是对于存储过程来说,相当于是将这一操作过程存储在数据库中,可以使用call与对其进行调用,并输入或者输出一些参数和结果。

印象最深的是类似“in n int”和“out sum int”这样的对于输入输出的定义,通过查看相关博客,可以总结如下对于输入输出定义的使用规律:

MySQL存储过程的参数用在存储过程的定义,共有三种参数类型

IN,OUT,INOUT
格式为:Create procedure|function([[IN |OUT |INOUT ] 参数名 数据类形...])

IN 输入参数
表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值

OUT 输出参数
该值可在存储过程内部被改变,并可返回

INOUT 输入输出参数
调用时指定,并且可被改变和返回

IN 和 OUT在实验中已有体会,主要是对INOUT的理解,这里引用一个例子:

参数inout的使用实例(既能输入一个值又能传出来一个值)
语句功能:传一个年龄,自动让年龄增长10岁
create procedure p3(inout age int)
begin
set age:=age+10;
end
其中:调用的时候,inout型的参数值既是输入类型又是输出类型,给它一个值,值不是变量,因此我们需要先设置一个变量并初始化这个值,调用的时候直接传这个变量即可。
set @currentAge=8$
call p3(@currentAge)$
select @currentAge$
创建并执行完存储过程,运行结果如下:

       数据库存储过程如何写

以上是数据库存储过程如何写的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: 数据库存储过程如何写

本文链接: https://www.lsjlt.com/news/51677.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 数据库存储过程如何写
    小编给大家分享一下数据库存储过程如何写,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!存储过程简介SQL语句需要先编译然后执行,而...
    99+
    2024-04-02
  • PHP编写数据库存储过程的方法
    随着Web应用程序的快速发展,数据库的需求也越来越大。PHP已经成为Web应用程序最广泛使用的语言之一,因为它非常灵活和易用。对于那些需要高效处理大量数据的应用程序来说,数据库存储过程已经成为一种非常重要的工具。通过使用存储过程,开发人员可...
    99+
    2023-05-15
    PHP编程语言 编写方法 数据库存储过程
  • oracle数据库如何查看存储过程
    可以通过以下步骤查看 oracle 数据库中的存储过程:1. 连接到数据库;2. 获取存储过程列表;3. 查看存储过程代码;4. 查看存储过程文档。 如何查看 Oracle 数据库中的...
    99+
    2024-04-19
    oracle
  • mysql数据库存储数据的过程
    这篇文章主要讲解了“mysql数据库存储数据的过程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql数据库存储数据的过程”吧! 存储过程如下: J...
    99+
    2024-04-02
  • mysql数据库的存储过程
    本篇内容介绍了“mysql数据库的存储过程”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 一、创建存储过...
    99+
    2024-04-02
  • Oracle存储过程编写:判断数据库表是否存在
    在Oracle数据库中,存储过程是一种可以保存并重复使用的一组SQL语句的集合,可以实现一定的逻辑功能。在编写Oracle存储过程的过程中常常会涉及到判断数据库表是否存在的需求,以便在...
    99+
    2024-03-08
    oracle 存储过程 判断表存在 sql语句
  • 如何实现PL/SQL中编写Oracle数据库分页的存储过程
    这篇文章主要为大家展示了“如何实现PL/SQL中编写Oracle数据库分页的存储过程”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何实现PL/SQL中编写Or...
    99+
    2024-04-02
  • 使用Golang编写高性能的数据库存储过程
    标题:利用Golang创建高效的存储过程 在软件开发过程中,存储过程是一种保存在数据库中的一组SQL语句集合,可以被客户端程序随时调用执行。存储过程可以提高数据库访问效率、减少网络传输...
    99+
    2024-02-24
    golang 存储过程 高效 go语言 sql语句
  • Oracle中如何编写存储过程
    在Oracle中编写存储过程可以使用PL/SQL语言。以下是一个在Oracle中编写存储过程的示例:```sqlCREATE OR ...
    99+
    2023-08-22
    oracle
  • 数据库怎么加密存储过程
    在数据库中对存储过程进行加密的方法首先,数据库中进行一个存储过程;CREATE PROCEDURE dbo.myPRoAS BEGINSELECT 'SQL statements'ENDGO存储过程新建好后,执行以下命令即可对存储过程进行加...
    99+
    2024-04-02
  • clickhouse存储过程如何导入数据
    在ClickHouse中,存储过程是通过使用SQL语句和函数来实现的。要导入数据到ClickHouse中,可以使用以下方法: 使用...
    99+
    2023-10-23
    clickhouse
  • Oracle数据库开发:编写存储过程判断表是否存在
    在Oracle数据库开发中,编写存储过程来判断表是否存在是一项常见的任务。在数据库开发中,存储过程是一段预先编译的代码块,用于实现特定的功能或逻辑。通过编写存储过程来判断表是否存在,可...
    99+
    2024-03-09
    oracle 存储过程 表存在
  • 如何在Oracle数据库中使用PL/SQL编写存储过程和触发器
    在Oracle数据库中使用PL/SQL编写存储过程和触发器,可以按照以下步骤进行操作: 使用SQL Developer或者其他O...
    99+
    2024-03-02
    Oracle
  • 数据库存储过程的示例分析
    这篇文章给大家分享的是有关数据库存储过程的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 select * from&nb...
    99+
    2024-04-02
  • mysql数据库存储过程之while循环
    一、语法。 while循环是有条件的循环控制语句,满足条件后,再执行循环体中的SQL语句,具体语法为: #先判定条件,如果条件为TRUE,则执行逻辑,否则不执行逻辑while 条件 do SQL逻辑 end while; 二、案例。 计...
    99+
    2023-09-21
    数据库 sql
  • Linux数据库的存储过程是什么
    在Linux上,存储过程是一组SQL语句的集合,它们被存储在数据库中并可以被调用和执行。存储过程通常用来执行一系列的操作,比如插入、...
    99+
    2024-05-06
    Linux 数据库
  • mysql数据的存储过程
    MySQL存储过程是一组预定义的SQL语句集合,可以在数据库中进行预先编译和存储,并在需要时进行调用和执行。存储过程通常用于处理复杂...
    99+
    2023-08-22
    MySQL
  • MySQL存储过程:简化数据库操作流程
    MySQL存储过程:简化数据库操作流程 MySQL存储过程是一组为了完成特定任务而预定义的SQL语句集合,可以被多次调用以执行相同的任务。通过存储过程,我们可以简化数据库操作的流程,提...
    99+
    2024-03-14
    mysql 存储过程 简化 sql语句
  • Android如何通过SQLite数据库实现数据存储管理
    这篇文章主要介绍了Android如何通过SQLite数据库实现数据存储管理,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。0 实验环境在Android Studio中进行有关代...
    99+
    2023-06-25
  • mysql数据库中的存储过程是什么
    这篇文章给大家分享的是有关mysql数据库中的存储过程是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。mysql存储过程是在大型数据库系统中,一组为了完成特定功能的SQL 语...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作