• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MySQL存储过程和事务的简单介绍

MySQL存储过程和事务的简单介绍

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MySQL,简单,事务等相关知识,希望本文的分享对您有所帮助
存储过程是通过一系列的SQL语句, 根据传入的参数(也可以没有), 通过简单的调用,
完成比单个SQL语句更复杂的功能, 存储在数据库服务器端,只需要编译过一次之后再次使用都不需要再进行编译。主要对存储的过程进行控制。
事务是一系列的数据更改操作组成的一个整体。一旦事务中包含的某操作失败或用户中止,用户可以控制将事务体中所有操作撤消,返回事务开始前的状态。
事务中的操作是一个整体,要么整体完成,要么全部不做。从而保证了数据的完整性。
Mysql中,MyISAM存储引擎不支持事务,InnoDB支持。
两者都是数据库中非常重要的知识。

存储过程:

优点:

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

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

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

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

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

缺点:

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

事务:

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

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

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

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

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

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

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

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

以上就是MySQL存储过程和事物的区别,希望对大家有所帮助。

相关推荐:

关于储存过程的详细介绍

为什么使用mysql储存过程?mysql储存过程简介

同时操作不同库里表,支持事物吗,mysql解决办法

以上就是MySQL存储过程和事务的简单介绍的详细内容,更多请关注微课江湖其它相关文章!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2018-12-05oracle sys_connect_by_path 函数 结果集连接
  • 2018-12-05Mysql常用基准测试工具
  • 2018-12-05mysql sql_mode="" 的作用说明
  • 2018-12-05SQL Server 7.0 入门(四)
  • 2018-12-05MySQL动态添加、删除和修改列字段教程
  • 2018-12-05手动编译安装Mysql
  • 2018-12-05mysql的基本命令介绍
  • 2018-12-05各大数据库分段查询技术的实现方式
  • 2018-12-05有关创建分组的文章推荐
  • 2018-12-05oracle 9i 图文安装/oracle 9i 安装

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 用VirtualBox构建MySQL测试环境的笔记
    • 如何在linux下修改mysql数据库密码?linux修改数据库密码的方法
    • 发现mysql一个用法,比较有用
    • 巧妙的自关联运用
    • 在ActiveReports中如何使用MySQL数据库
    • SQLServer 循环批处理
    • mysql进阶(二十三)数据库事务四大特性
    • 解析MySQl中的模糊匹配
    • mysql安装配置详解教程(一)_MySQL
    • Oracle用SYS和SYSTEM默认密码登录提示 ORA-01017:invalid userna

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有