iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL存储过程都有哪些
  • 274
分享到

MySQL存储过程都有哪些

2024-04-02 19:04:59 274人浏览 独家记忆
摘要

今天就跟大家聊聊有关Mysql存储过程都有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  mysql存储过程有哪些  --假设根据user_i

今天就跟大家聊聊有关Mysql存储过程都有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

  mysql存储过程有哪些

  --假设根据user_id分表,分成64张

  insertintotable_new_0000select*fromtable_oldwheremod(user_id,64)=0;insertintotable_new_0001select*fromtable_oldwheremod(user_id,64)=1;...

  一共64条sql,OK搞定。但是这个一张表被全表扫描了64次,做的无用功比较多,而且导致停机时间比较长。

  虽然MySQL存储过程不是很熟,稍稍学习了下写了两个脚本,一个全量+一个增量脚本完成表的拆分。

  线上库也实践了下,8个分表,每个分表1000W记录拆分到64个分表。

  全量时间150分钟,全量的时候几个分表可以一起跑,我是同时跑3个分表

  增量时间每个分表4分钟4个一起跑,一共是8分钟搞定。这样停机时间加上应用的发布一共只需要20分钟就可以搞定了。

  附脚本:

  ###################

  delimeter//

  -----------

  ---全量脚本:

  CREATEPROCEDUREsp_xf_move_item()begindeclarev_exitintdefault0;declarev_spidbigint;declarev_idbigint;declareiintdefault0;declarec_tableint;

  --定义游标(要分拆的表,定义一个数量的截止时间)

  declarec_idscursorforselectid,user_idfromitem_records_0000wheregmt_modified<'2010-8-2500:00:00';declarecontinuehandlerfornotfoundsetv_exit=1;openc_ids;repeat ifv_exit="0thenset@vv_id=v_id;" sql="" sql_context="CONCAT('insertintoitem_record_',LPAD(c_table,4,0),'select*fromitem_records_0000whereid=');PREPARESTMTFROM@SQL_CONTEXT;--执行sqlEXECUTESTMTusing@vv_id;DEALLOCATEPREPARESTMT;endif;setii=i+1;" auto_commit="" untilv_exit="1endrepeat;closec_ids;commit;end;//-----------setauto_commit=0;callsp_xf_move_item();####增量脚本######CREATEPROCEDUREsp_xf_add_item()begindeclarev_exitintdefault0;declarev_spidbigint;declarev_idbigint;declareiintdefault0;declarec_tableint;declarec_idscursorforselectid,supplier_idfromitem_records_0000wheregmt_modified">='2010-8-2500:00:00';declarecontinuehandlerfornotfoundsetv_exit=1;openc_ids;repeatfetchc_idsintov_id,v_spid;ifv_exit=0thenset@vv_id=v_id;set@v_row=0;selectmod(v_spid,64)intoc_table;

  --判断数据是否已经存在

  SET@SQL_C=CONCAT('selectcount(*)into@v_rowfromitem_record_',LPAD(c_table,4,0),'whereid=');PREPARESTMT_CFROM@SQL_C;EXECUTESTMT_Cusing@vv_id;DEALLOCATEPREPARESTMT_C;SET@SQL_INSERT=CONCAT('insertintobbc_item_record_',LPAD(c_table,4,0),'select*fromitem_records_0000whereid=');PREPARESTMT_IFROM@SQL_INSERT;SET@SQL_DELETE=CONCAT('DELETEFROMbbc_item_record_',LPAD(c_table,4,0),'whereid=');PREPARESTMT_DFROM@SQL_DELETE;

  --如果数据已经存在,则先delete在insert

  if@v_row>0thenEXECUTESTMT_Dusing@vv_id;DEALLOCATEPREPARESTMT_D;endif;EXECUTESTMT_Iusing@vv_id;DEALLOCATEPREPARESTMT_I;endif;setii=i+1;ifmod(i,100)=0thencommit;endif;untilv_exit=1endrepeat;closec_ids;commit;end;//-------

  如果全量和增量之间的时间拖的比较长,那么可以设置时间,多做几次增量已缩短最后的停机时间,你懂的。。。

  callsp_xf_add_item()//

看完上述内容,你们对MySQL存储过程都有哪些有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网数据库频道,感谢大家的支持。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL存储过程都有哪些

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

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

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

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

下载Word文档
猜你喜欢
  • MySQL存储过程都有哪些
    今天就跟大家聊聊有关MySQL存储过程都有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  MySQL存储过程有哪些  --假设根据user_i...
    99+
    2024-04-02
  • MySQL存储引擎都有哪些
    这篇文章将为大家详细讲解有关MySQL存储引擎都有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。  MySQL 的存储引擎存储引擎  ARCHIVE用于...
    99+
    2024-04-02
  • mysql储存过程有哪些优点
    这篇文章给大家分享的是有关mysql储存过程有哪些优点的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。但是在数据库的实际操作中,经常会有一个完整的操作需要多条 SQL 语句处理多个...
    99+
    2024-04-02
  • mysql存储过程和存储函数有哪些区别
    本文小编为大家详细介绍“mysql存储过程和存储函数有哪些区别”,内容详细,步骤清晰,细节处理妥当,希望这篇“mysql存储过程和存储函数有哪些区别”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起...
    99+
    2024-04-02
  • mysql存储过程的缺点有哪些
    今天小编给大家分享一下mysql存储过程的缺点有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解...
    99+
    2024-04-02
  • mysql存储过程与存储函数的区别有哪些
    这篇文章主要讲解了“mysql存储过程与存储函数的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql存储过程与存储函数的区别有哪些”吧! ...
    99+
    2024-04-02
  • mysql存储过程有哪些变量类型
    这篇文章主要讲解了“mysql存储过程有哪些变量类型”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql存储过程有哪些变量类型”吧! ...
    99+
    2024-04-02
  • mysql存储过程的优缺点有哪些
    这篇文章给大家介绍mysql存储过程的优缺点有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、优点(1)处理封装在易于使用的单元中,简化了复杂的操作;(2)由于不需要重复建立一系列处理步骤,因此保证了数据的完整性...
    99+
    2023-06-15
  • mysql存储过程有哪些使用技巧
    mysql存储过程有哪些使用技巧?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!mysql存储过程使用技巧有:1、创建带in...
    99+
    2024-04-02
  • MySQL中存储过程的优缺点有哪些
    这篇文章给大家介绍MySQL中存储过程的优缺点有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。存储过程可以有效提高 SQL 语句的复用率,并且可以将相关的一组 SQL 放入到存储过程中,从而避免了应用程序的多次查询...
    99+
    2023-06-15
  • mysql调用存储过程的方式有哪些
    在MySQL中调用存储过程有以下几种方式: 使用CALL语句调用存储过程:可以使用CALL语句来直接调用存储过程,例如:CALL ...
    99+
    2024-04-09
    mysql
  • mysql使用存储过程的作用有哪些
    这篇文章将为大家详细讲解有关mysql使用存储过程的作用有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。mysql使用存储过程的作用:1、增强SQL语句的功能和灵活性...
    99+
    2024-04-02
  • mysql储存过程中循环语句有哪些
    mysql存储过程中提供while和repeat两种循环语句:while循环:根据条件重复执行代码块,条件为真时继续执行。repeat循环:先执行代码块,再检查条件是否为真,为假则再次执...
    99+
    2024-04-22
    mysql 代码可读性
  • SQLServer分页存储过程有哪些
    本篇文章为大家展示了SQLServer分页存储过程有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  SQLServer分页存储过程有哪几种方法  创建数据库d...
    99+
    2024-04-02
  • mysql有存储过程吗
    这篇文章主要介绍“mysql有存储过程吗”,在日常操作中,相信很多人在mysql有存储过程吗问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql有存储过程吗”的疑惑有所帮...
    99+
    2024-04-02
  • MySQL存储过程详解 mysql 存储过程
    mysql存储过程详解 1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Proce...
    99+
    2024-04-02
  • mysql存储过程保存在哪
    mysql 存储过程保存在 mysql.proc 表中,该表存储了存储过程的所有信息,包括名称、定义、创建者和修改时间。 MySQL 存储过程保存在哪里? MySQL 中的存储过程保存...
    99+
    2024-04-22
    mysql
  • LINQ存储过程有哪些优缺点
    这篇文章主要讲解了“LINQ存储过程有哪些优缺点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“LINQ存储过程有哪些优缺点”吧!一、何谓存储过程?存储过程者,乃是存放在数据库中的一个脚本也。...
    99+
    2023-06-17
  • sql存储过程的优点有哪些
    这篇文章主要介绍sql存储过程的优点有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!sql存储过程实例详解存储过程(Stored Procedure),是一组为了完成特定功能的S...
    99+
    2024-04-02
  • mysql存储过程在哪里写
    mysql 存储过程存储在 mysql 数据库中的 mysql.proc 表中。创建存储过程需要使用 create procedure 语句,调用存储过程需要使用 call 语句。 M...
    99+
    2024-04-22
    mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作