MySQL数据库存储过程和事务的区别讲解

 更新时间:2019年03月19日 09:58:30   作者:CODETC  
今天小编就为大家分享一篇关于MySQL数据库存储过程和事务的区别讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

事务是保证多个SQL语句的原子型的,也就是要么一起完成,要么一起不完成

存储过程是把一批SQL语句预编译后放在服务器上,然后可以远程调用

存储过程:

一组为了完成特定功能的SQL语句集(或者自定义数据库操作命令集), 根据传入的参数(也可以没有), 通过简单的调用, 完成比单个SQL语句更复杂的功能, 存储在数据库服务器端,只需要编译过一次之后再次使用都不需要再进行编译:主要对存储的过程进行控制。

优点:

1、执行速度快。尤其对于较为复杂的逻辑,减少了网络流量之间的消耗,另外比较重要的一点是存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般 SQL 语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。。

2、提高工作效率。写程序简单,采用存储过程调用类,调用任何存储过程都只要1-2行代码。

3、规范程序设计,升级、维护方便。

4、提高系统安全性。可设定只有某用户才具有对指定存储过程的使用权。

数据量小的,或者和钱没关系的项目不用存储过程也可以正常运作。mysql 的存储过程还有待实际测试。如果是正式项目,建议你用 sql server 或 oracle 的存储过程。数据与数据之间打交道的话,过程会比程序来的快的多。

缺点:

程序部分功能移到了数据库内,破坏了CVM三层结构设计

事务:

一系列的数据更改操作组成的一个整体。这些操作包括存储过程,更改语句及其它操作。一旦事务中包含的某操作失败或用户中止,用户可以控制将事务体中所有操作撤消,返回事务开始前的状态。事务中的操作是一个整体,要么整体完成,要么全部不做。从而保证了数据的完整性。

事务中可以有存储过程 存储过程中也可以有事务。

什么时候使用存储过程比较适合?

1、当一个业务同时对多个表进行处理的时候采用存储过程比较合适。

2、复杂的数据处理用存储过程,如有些报表处理。

3、多条件多表联合查询,并做分页处理。

什么时候使用事务比较适合?

每次使用事务,都会占用一定的开销。另外,事务可能会锁定一些表的行。所以,不必要的事务会导致性能损失。这里有一个规则,只有当操作需要的时候才使用事务。例如,如果只是从数据库中查询一些记录,或者执行单个查询,在大部分时候都不需要显式的事务,因为声明都已经封装在隐式的事务中。但是,正如前文提到,在多声明更新时非常重要,因为事务能够实际提升操作速度。同样,如果需要在节省数毫秒时间和危害数据完整性之间做出一个选择的话,那么正确的答案就是保持数据清洁,不要担心那数毫秒的时间消耗。

另外使用事务之前需要注意的是:尽可能短的保持事务。避免使用在事务中的SELECT返回数据,除非语句依赖于返回数据。如果使用SELECT语句,只选择需要的行,因此不要锁定过多的资源同时保持尽可能高的性能。在架构语序的情况下,从事务中移出所有SELECT语句。这么做是因为事务在处理的过程中会锁定所有被操作的数据行,这样会影响其他并发的sql语句的执行。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

相关文章

  • Mysql8.0压缩包安装方法(详细教程一步步安装)

    Mysql8.0压缩包安装方法(详细教程一步步安装)

    这篇文章主要给大家介绍了关于Mysql8.0压缩包安装方法,文中介绍的非常详细,Mysql安装的时候可以有msi安装和zip解压缩两种安装方式,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • MySQL 分表分库怎么进行数据切分

    MySQL 分表分库怎么进行数据切分

    这篇文章主要介绍了MySQL 分表分库怎么进行数据切分,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-03-03
  • 如何查看MySQL连接的root密码

    如何查看MySQL连接的root密码

    前几天在用Navicat去连本地的MySQL的时候发现我已经忘了密码了,试了网上很多方式都不行…后来发现其实可以自己直接去看当初设置的密码,下面将方法总结出来分享给大家,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2017-01-01
  • MySQL中外键的创建、约束以及删除

    MySQL中外键的创建、约束以及删除

    这篇文章主要给大家介绍了关于MySQL中外键的创建、约束以及删除的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • Mysql三种常用的删除数据或者表的方式

    Mysql三种常用的删除数据或者表的方式

    本文主要介绍了Mysql三种常用的删除数据或者表的方式,它们分别是 TRUNCATE、DROP 和 DELETE,下面就详细的介绍一下这三种的使用,感兴趣的可以了解一下
    2024-01-01
  • 配置mysql允许远程连接的方法

    配置mysql允许远程连接的方法

    默认情况下,MySQL只允许本地登录,如果要开启远程连接,则需要修改/etc/my.cnf文件
    2013-02-02
  • MySQL事务(transaction)看这篇就足够了

    MySQL事务(transaction)看这篇就足够了

    M事务的实现是基于数据库的存储引擎,不同的存储引擎对事务的支持程度不一样,下面这篇文章主要给大家介绍了关于MySQL事务(transaction)的相关资料,需要的朋友可以参考下
    2022-11-11
  • mysql 5.5.27 winx64安装配置方法图文教程

    mysql 5.5.27 winx64安装配置方法图文教程

    这篇文章主要为大家详细介绍了mysql5.5.27 winx64安装配置方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • 项目从MYSQL迁移至MARIADB教程

    项目从MYSQL迁移至MARIADB教程

    本文给大家分享的是将项目从MySQL迁移至MariaDB的详细步骤,非常的实用,有需要的小伙伴可以参考下
    2017-07-07
  • mysql 8.0.12 快速安装教程

    mysql 8.0.12 快速安装教程

    这篇文章主要为大家详细介绍了mysql 8.0.12的快速安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08

最新评论