首页 数据库 mysql教程 MySQL5新特点(存储过程)

MySQL5新特点(存储过程)

Jun 07, 2016 pm 04:04 PM
m 存储 支持 特点 过程

支持存储过程是MySQL5中一个很重要的新增特性。虽然有些用户不希望将反映业务逻辑的流程通过存储过程封装在数据库中,但大多数的数据库管理人员还是非常喜欢在数据库中能使用存储过程这一功能,因为存储过程有很多好处: 用户可以重用代码和更改控制 -和将业

支持存储过程是MySQL5中一个很重要的新增特性。虽然有些用户不希望将反映业务逻辑的流程通过存储过程封装在数据库中,但大多数的数据库管理人员还是非常喜欢在数据库中能使用存储过程这一功能,因为存储过程有很多好处:
用户可以重用代码和更改控制
-和将业务逻辑流程写入多个应用程序不同的是,用户只需要写 一次存储过程就可以立刻使用许多应用程序来调用该过程,从而实现特定的业务逻辑流程。数据库管理员也可以通过标准的管理函数来处理不同版本中的数据库资源,比如数据库结构 和安全权限等。
可以获得快速的性能
-管理员可以存储过程中使用循环结构来执行多个SQL语句,而之前应用程序每次只能执行一条SQL语句,效率明显得到提高,也可以把复杂的多个SQL语句写入一个存储过程,不太熟练SQL语句的用户可以直接调用该存储过程,从而避免了在书写复杂SQL语 句时可能出现的错误。
更容易的安全管理特性
-对于一个服务大量不同用户的复杂数据库来说,将数量巨大的数据对象的使用权限分配给不同用户是相当费时的,使用存储过程以后,就可以在过程级进行权限 分配的任务,比如,当用户的一个SQL查询语句需要访问10张不同的表时,若不用存储过程, 就需要为该用户进行10次不同的表许可权限分配,而使用存储过程后只需要对含有该SQL查询 语句的存储过程分配一次许可权限就可以了。
减少了网络通信流量
-原先通过网络的多次调用,写入单个存储过程中放在服务器端后,进行一次存储过程调用就可以完成,从而减少了过量的网络通信流量。
很象DB2数据库,MySQL5中的存储过程也完全符合ANSI SQL 2003标准,非常方便开发人员和数据库管理员学习和使用,而且select查询语句的返回结果也很直观,无须专用的调用包和参考游标,这点类似于微软SQLserver和sybase数据库,下面是一个关于输出的例子:

mysql> delimiter //
mysql> create procedure top_broker()
    -> select a.broker_id,
    ->        a.broker_first_name,
    ->        a.broker_last_n
    ->        sum(broker_commission) total_commissions
    ->   from broker a,
    ->        client_transaction b
    ->   where a.broker_id=b.broker_id
    -> group by a.broker_id,
    ->        a.broker_first_name,
    ->        a.broker_last_name
    -> order by 4 desc;
    -> //
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ;
mysql> call top_broker();
登录后复制

为了处理标准的查询输出,MySQL5的存储过程中支持了许多常见的开发构造,比如:

输入/输出参数;
变量定义;
带EXIST检查的循环;
逻辑条件判断(if,case等);
条件处理柄;
存储过程调用存储过程;
对事务处理类数据库表的“提交/撤销”功能支持;
数据定义语句等等。
登录后复制
数据库开发和管理人员可以通过create,alter,drop,grant来具体操作MySQL5中的存储过程, 除了获得元数据的特殊存储过程,还可以通过如下方法来操作存储过程:
使用show procedure status函数;
查询mysql.proc内置表;
使用MySQL5的另一个新特性-information_schema数据字典来实现。
登录后复制

(51CTO.COM教程)


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

华为明年将推创新 MED 存储产品:机架容量超过 10 PB,功耗低于 2 kW 华为明年将推创新 MED 存储产品:机架容量超过 10 PB,功耗低于 2 kW Mar 07, 2024 pm 10:43 PM

本站3月7日消息,华为数据存储产品线总裁周跃峰博士日前出席MWC2024大会,专门展示了为温数据(WarmData)和冷数据(ColdData)设计的新一代OceanStorArctic磁电存储解决方案。华为数据存储产品线总裁周跃峰发布系列创新解决方案图源:华为本站附上华为官方新闻稿内容如下:该方案的成本比磁带低20%,功耗比硬盘低90%。根据国外科技媒体blocksandfiles报道,华为发言人还透露了关于该磁电存储解决方案的信息:华为的磁电磁盘(MED)是对磁存储介质的重大创新。第一代ME

自媒体到底是什么?它的主要特点和功能有哪些? 自媒体到底是什么?它的主要特点和功能有哪些? Mar 21, 2024 pm 08:21 PM

随着互联网的快速发展,自媒体这个概念已经深入人心。那么,自媒体到底是什么?它有哪些主要特点和功能呢?接下来,我们将一一探讨这些问题。一、自媒体到底是什么?自媒体,顾名思义,就是自己就是媒体。它是指通过互联网平台,个人或者团队可以自主创建、编辑、发布和传播内容的信息载体。不同于传统媒体,如报纸、电视、电台等,自媒体具有更强的互动性和个性化,让每个人都能成为信息的生产者和传播者。二、自媒体的主要特点和功能有哪些?1.低门槛:自媒体的崛起降低了进入媒体行业的门槛,不再需要繁琐的设备和专业的团队,一部手

Ubuntu上的Git安装过程 Ubuntu上的Git安装过程 Mar 20, 2024 pm 04:51 PM

Git是一个快速、可靠、适应性强的分布式版本控制系统。它旨在支持分布式的非线性工作流,使其成为各种规模的软件开发团队的理想选择。每个Git工作目录都是一个独立的存储库,具有所有更改的完整历史记录,并能够跟踪版本,即使没有网络访问或中央服务器。GitHub是托管在云上的Git存储库,它提供了分布式修订控制的所有功能。GitHub是Git的存储库,托管在云上。与作为CLI工具的Git不同,GitHub有一个基于Web的图形用户界面。它用于版本控制,这涉及到与其他开发人员协作,并跟踪随时间推移对脚本和

PHP版本NTS的含义及特点 PHP版本NTS的含义及特点 Mar 26, 2024 pm 12:39 PM

PHP是一种流行的开源脚本语言,被广泛用于Web开发中。而PHP版本中的NTS则是一个重要的概念,本文将介绍PHP版本NTS的含义及特点,并提供具体的代码示例。1.什么是PHP版本NTS?NTS是Zend官方提供的一个PHP版本的变体,全称为NotThreadSafe(非线程安全)。通常PHP版本分为TS(ThreadSafe,线程安全)和NTS两种

什么是LEO币?LEO币有什么特点? 什么是LEO币?LEO币有什么特点? Mar 06, 2024 am 09:31 AM

LEO币:币安交易所的原生代币LEO币是币安交易所发布的原生代币,于2019年推出。作为多功能的实用代币,LEO币为币安用户提供一系列福利和特权。LEO币的特点:交易费用折扣:持有LEO币可享受币安交易所交易费用的折扣,最高可达25%。VIP会员资格:根据持有的LEO币数量,用户可获得不同的VIP会员等级,享受更多专属福利。投票权:LEO币持有者有权对币安交易所的重大决策进行投票,参与平台治理。生态系统应用:LEO币可用于支付币安生态系统中的各种服务和产品,例如币安Launchpad、币安DEX

什么是Axelar币?Axelar币有什么特点? 什么是Axelar币?Axelar币有什么特点? Mar 06, 2024 am 10:20 AM

Axelar:跨链互操作性的未来Axelar是一个旨在解决不同区块链之间互操作性问题的跨链通信协议。通过Axelar,开发人员能够轻松构建跨链应用程序,实现资产和数据在多个区块链之间的无缝转移。Axelar的特点:通用跨链通信:Axelar提供了一个通用平台,允许不同区块链之间的双向通信。安全且可扩展:Axelar使用分布式验证器网络(DVN)来确保交易的安全性和可扩展性。跨链资产转移:Axelar使得在不同区块链之间转移资产成为可能,包括原生代币、稳定币和NFT。数据互操作性:Axelar允许

什么是Ondo币?Ondo币有什么特点? 什么是Ondo币?Ondo币有什么特点? Mar 06, 2024 pm 08:22 PM

Ondo币:具有无限可能性的数字货币Ondo币是一种基于区块链技术的创新数字货币,旨在成为未来数字经济的基石。它拥有以下特点:高扩展性:Ondo币采用独特的共识机制,能够处理每秒数千笔交易,满足大规模应用的需求。低交易费用:Ondo币的交易费用极低,为用户提供经济实惠的交易体验。快速确认:Ondo币交易确认时间极快,通常只需几秒钟,为用户带来高效的交易体验。安全性:Ondo币采用先进的加密技术,确保交易安全可靠,保护用户资产。生态友好:Ondo币的共识机制采用权益证明(PoS),比工作量证明(P

什么是Manta币?Manta币有什么特点? 什么是Manta币?Manta币有什么特点? Mar 06, 2024 pm 10:50 PM

Manta币:隐私保护的去中心化金融利器Manta币(MANTA)是一种基于MantaNetwork的隐私保护代币,旨在为去中心化金融(DeFi)用户提供更加安全和私密的交易环境,增强用户交互体验。特点:隐私保护:Manta币利用零知识证明技术,允许用户在不透露交易详情的情况下验证交易。可扩展性:MantaNetwork采用分片技术,提高了交易吞吐量和可扩展性。跨链互操作性:Manta币支持跨多个区块链的交易,包括以太坊、波卡和Kusama。去中心化:MantaNetwork由分布式节点网络管理

See all articles