原文:mysql存储过程之游标遍历数据表 今天写一个mysql存储过程,根据自己的需求要遍历一个数据表,因为对存储过程用的不多,语法不甚熟悉,加之存储过程没有调试环境,花了不少时间才慢慢弄好,故留个痕迹. 1 BEGIN 2 DECLARE Done INT DEFAULT 0; 3 4 DECLARE CurrentLingQi INT; 5 6 DECLARE ShizuName VARCHAR(30); 7 /* 声明游标 */ 8 DECLARE rs CURSOR FOR SELECT…
MySQL存储过程之游标实战 ​ 博主日前在解决一个项目需求时,没有什么好的方法,于是就来学习存储过程了,之前也是接触过,奈何年少贪玩,竟是全部又还给了大学老师-苦不堪言呐-. ​ 先说一下业务需求吧,即要求查询出一套包含父子类别的数据,其结构是父类别有N条记录,并且要保证可以分页查询,与父类别对应的子类别要有N1条记录.该问题在之前的之前在度娘上面问过,然而无果.最近领导又提出了类似的需求,嗯.只能想办法了. 博主首先想到的就是left join,但是使用表连接的结果则是子类别的所以数据与父类…
MariaDB.MySQL存储过程.游标基础应用举例说明 by:授客 QQ:1033553122 测试环境: MariaDB-10.0.19-centos7-x86_64 实践操作: # 创建测试数据库 DROP DATABASE IF EXISTS testdb1; CREATE DATABASE testdb1; # 创建测试表-余额表 DROP TABLE IF EXISTS account; CREATE TABLE IF NOT EXISTS account (user_id BIGI…
MySQL5 中添加了存储过程的支持. 大多数SQL语句都是针对一个或多个表的单条语句.并非所有的操作都怎么简单.经常会有一个完整的操作需要多条才能完成  存储过程简单来说,就是为以后的使用而保存的一条或多条MySQL语句的集合.可将其视为批文件.虽然他们的作用不仅限于批处理.  为什么要使用存储过程:优点 1 通过吧处理封装在容易使用的单元中,简化复杂的操作 2 由于不要求反复建立一系列处理步骤,这保证了数据的完整性.如果开发人员和应用程序都使用了同一存储过程,则所使用的代码是相同的.还有就是…
MySQL5 中添加了存储过程的支持.     大多数SQL语句都是针对一个或多个表的单条语句.并非所有的操作都怎么简单.经常会有一个完整的操作需要多条才能完成     存储过程简单来说,就是为以后的使用而保存的一条或多条MySQL语句的集合.可将其视为批文件.虽然他们的作用不仅限于批处理.     为什么要使用存储过程:优点         1 通过吧处理封装在容易使用的单元中,简化复杂的操作         2 由于不要求反复建立一系列处理步骤,这保证了数据的完整性.如果开发人员和应用程序都…
一.MySQL游标的概念 游标介绍: MySQL的游标(cursor)是一个重要的概念,通过查找资料与自己的理解,主要得出以下几点关于自己的理解. 有数据缓冲的思想:游标的设计是一种数据缓冲区的思想,用来存放SQL语句执行的结果. 先有数据基础:游标是在先从数据表中检索出数据之后才能继续灵活操作的技术.   类似于指针:游标类似于指向数据结构堆栈中的指针,用来pop出所指向的数据,并且只能每次取一个. 游标优缺点: 游标的优点: 因为游标是针对行操作的,所以对从数据库中select查询得到的每一…
一.存储过程 什么是存储过程,为什么要使用存储过程以及如何使用存储过程,并且介绍创建和使用存储过程的基本语法. 什么是存储过程: 存储过程可以说是一个记录集,它是由一些T-SQL语句组成的代码块,这些T-SQL语句代码像一个方法一样 实现一些功能(对单表或多表的增删改查),然后再给这个代码块取一个名字,在用到这个功能的时候调用 他就行了. 存储过程的好处: 由于数据库执行动作时,是先编译后执行的.然而存储过程是一个编译过的代码块,所以执行效率要比 T-SQL语句高. 一个存储过程在程序在网络中交…
GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 内容提纲 一.测试环境搭建 二.执行过程解析 三.注意事项 一.测试环境搭建 首先创建一张表,并插入几行数据字段: CREATE TABLE t (s1 INT, s2 char(100),PRIMARY KEY (s1)); INSERT INTO t values(1,'aaa'); INSERT INTO t values(2,'bbb'); INSERT INTO t values(3,'ccc'); 接着创建…
-- 完整例子 CREATE PROCEDURE test BEGIN -- 定义参数    DECLARE _id INT; -- 定义游标    DECLARE no_more_products INT DEFAULT 0;    DECLARE RESULT_test CURSOR FORSELECT num1 from numtest; -- 如果NOT FOUND游标DECLARE  CONTINUE HANDLER FOR NOT FOUND  SET  no_more_produc…
-- 大表数据迁移,每天凌晨1点到5点执行,执行间隔时间10分钟,迁移旧数据到历史表. DELIMITER $$ USE `dbx`$$ DROP PROCEDURE IF EXISTS `pro_xx`$$ CREATE  PROCEDURE `pro_xx`() BEGIN DECLARE p_oalid INT DEFAULT 0; DECLARE STOP INT DEFAULT 0; DECLARE cur_oalid CURSOR FOR SELECToal.id FROM oal_…
DELIMITER $$ DROP PROCEDURE IF EXISTS `procedure_course`$$ CREATE DEFINER=`root`@`localhost` PROCEDURE `topsale`.`procedure_course`() BEGIN DECLARE c_user_login_id VARCHAR(100); DECLARE done INT DEFAULT 0; ##1.定义游标stock_cursor 根据指定用户id DECLARE stock_…
CREATE DEFINER=`root`@`%` PROCEDURE `vir`.`task_payment_byonlinedown`()begin declare _mobile varchar(12) ; declare _amount decimal(18,4) default 0; declare _reduce_amount decimal(18,4) default 0; declare _is_part varchar(12) ; declare _excute_status…
CREATE DEFINER=`root`@`localhost` PROCEDURE `NewProc`() BEGIN #Routine body goes here... DECLARE itemId varchar(64); -- id DECLARE AA varchar(64); -- 省 DECLARE BB varchar(64); -- 市 DECLARE CC varchar(64); -- 区 DECLARE new_province varchar(64); -- 省 D…
-- -------------------------------------------------------------------------------- -- Routine DDL -- Note: comments before and after the routine body will not be stored by the server -- ---------------------------------------------------------------…
delimiter $$DROP PROCEDURE IF EXISTS pro_test ;CREATE PROCEDURE pro_test()begin DECLARE var_name varchar(50); DECLARE fee_18 CURSOR FORselect name from test;DECLARE EXIT HANDLER FOR NOT FOUND CLOSE fee_18; OPEN fee_18;REPEATFETCH fee_18 into var_name…
MySQL存储过程  游标 如何在存储过程中使用MySQL游标来遍历SELECT语句返回的结果集 MySQL游标简介 要处理存储过程中的结果集,请使用游标.游标允许您迭代查询返回的一组行,并相应地处理每行. MySQL游标为只读,不可滚动和敏感. 只读:无法通过光标更新基础表中的数据. 不可滚动:只能按照SELECT语句确定的顺序获取行.不能以相反的顺序获取行. 此外,不能跳过行或跳转到结果集中的特定行. 敏感:有两种游标:敏感游标和不敏感游标.敏感游标指向实际数据,不敏感游标使用数据的临时副本…
1.存储过程 存储过程是什么,简单来讲,就像Java中的方法(函数),不过它是SQL世界中的方法. 大部分时候,我们所使用都是单条SQL,用来针对一个或多表连接.但是也有情况,是据判断先对表A执行操作,变动后再结合表B进行操作.即SQL的执行可能需要考虑包含业务规则在内的智能处理.封装操作的好处就不过多说明,无非是简化,复用,降低耦合等,同时,它还具有更高的性能. 考虑这种业务情况,现在你需要获得订单总额,但同时需要增加营业税,且只针对某些顾客,那么你需要: 获得基本的订单总额 将营业税有条件地…
自己写的一个mysql存储过程如下: BEGIN DECLARE _did bigint(20);DECLARE _count int;DECLARE s1 int;DECLARE cur_1 CURSOR FOR select id from info; /** 声明游标,并将查询结果存到游标中 **/ /** 获取查询数量 **/ SELECT count(id) into _count from info;SET s1=1;START TRANSACTION;#开启事务open cur_1…
Mysql 存储过程中使用多游标 drop procedure IF EXISTS test_proc_1; create procedure test_proc_1() begin ; ) ; ) DEFAULT NULL; ) DEFAULT NULL; DECLARE cur_1 CURSOR FOR select name, password from netingcn_proc_test; DECLARE cur_2 CURSOR FOR select id, name from ne…
MySQL中的存储过程首先来看两个问题: 1.什么是存储过程? 存储过程(Stored Procedure)是在数据库系统中,一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给出参数(如果该存储过程有参数的话)来执行它. 2.为什么要使用存储过程? <MySQL必知必会>这本书中给出了如下几条主要理由: 1)通过把处理封装在容易使用的单元中,简化复杂的操作: 2)由于不要求反复建立一系列处理步骤,这保证了数据的完整性. 如果所有开发人员和应用程序都使用同…
这里我新建了两个表,一个users和test CREATE TABLE users( username ), pwd ) ); CREATE TABLE test( id INT, username ) ) 这里向users表中插入了多条数据,主要是为了测试存储过程和游标的使用 1.不带参数的存储过程,从users表中查出所有数据 BEGIN SELECT * FROM users; END 结果和上图一样 2.带参数的存储过程 BEGIN SELECT * FROM users WHERE p…
一.首先说下本篇博客所实现功能的背景和功能是怎样的: 背景:因为公司项目开始迁移新平台项目,所以以前的平台老数据以及订单信息需要拆分表,而且需要业务逻辑来分析以前的订单表,来拆分成另外的几个新表,包括增加新的流水分析,以及更新其他用户或者商家的余额以及对账信息. 功能:需要查询出某个日期节点后的几十万条订单信息,循环遍历每条订单,获取每条订单的交易额,从而根据订单中的商家id和用户id来更新用户表中的积分或者余额信息,并且要在循环中为商家保存流水. 讲解:其实这个存储过程一点都不难,主要是本人在…
MySQL 存储过程 ```sql CREATE PROCEDURE myprocedure (IN para01 INTEGER) BEGIN DECLARE var01 CHAR(10); IF para01 = 17 THEN SET var01 = 'birds'; ELSE SET var01 = 'beasts'; END IF; INSERT INTO table1 VALUES(var01); END ``` 创建实例 ```sql CREATE PROCEDURE p1 /*声…
PHP调用MYSQL存储过程实例 标签: mysql存储phpsqlquerycmd 2010-09-26 11:10 11552人阅读 评论(3) 收藏 举报 实例一:无参的存储过程$conn = mysql_connect('localhost','root','root') or die ("数据连接错误!!!");mysql_select_db('test',$conn);$sql = "create procedure myproce()beginINSERT IN…
最近几天在研究hibernate.JPA对存储过程的调用,主要是针对有返回结果集的存储过程的调用方法,个人感觉存储过程是个好东西,虽然说heibernate对数据访问封装的比较不错,再加上他的缓存机制,确实很多情况下足够了,不过存储过程还是有他的用武之地,如果能用他提高性能,为何不用.... 好吧,不讨论他有没有用处,掌握了以后备用也是不错的选择,重点看看oracle的存储过程调用,mysql的要简单的多. (一).oracle存储过程调用 先在pl/sql中建立一个存储过程,代码如下: --创…
Mysql存储过程查询结果赋值到变量的方法   把查询结果赋值到变量,大部分情况下使用游标来完成,但是如果明确知道查询结果只有一行(例如统计记录的数量,某个字段求和等),其实可以使用set或into的方式来实现赋值.示例代码: 01 drop table if exists test_tbl; 02 create table test_tbl (name varchar(20), status int(2)); 03 insert into test_tbl values('abc', 1),(…
本书结构: 第一部分:存储编程基础 第1章:存储过程程序基础 第2章:MySQL存储编程指南 第3章:语言基础 第4章:语句块 第5章:在存储程序中使用SQL 第一章:MySQL存储程序介绍 存储程序包含存储过程,函数和触发器.正确使用存储程序也有助于加强数据库的安全性和完整性以及改善你的应用程序的性能和易维护性. 1.1 什么是存储程序 一种被数据库服务器所存储和执行的计算机程序,存储程序的源代码可能是二进制编译版本,几乎总是占据着数据库服务器系统的表空间,程序总是位于其数据库服务器的进程或线…
虽然MySQL的存储过程,一般情况下,是不会使用到的,但是在一些特殊场景中,还是有需求的.最近遇到一个sql server向mysql迁移的项目,有一些sql server的存储过程需要向mysql迁移.所以进行复习了一下.下面是一些存储过程的例子. 1. 例子1 DELIMITER // DROP PROCEDURE IF EXISTS loginandreg // CREATE PROCEDURE loginandreg( OUT userId BIGINT, ), ), ) ) BEGIN…
PHP调用MYSQL存储过程实例 http://blog.csdn.net/ewing333/article/details/5906887 http://www.cnblogs.com/kkcheng/archive/2010/03/19/1689672.html http://hi.baidu.com/dreamontheway/item/8041f26ad5070131ad3e8346 实例一:无参的存储过程 $conn = mysql_connect('localhost','root'…
Mysql存储过程知识,案例: create procedure delete_setting(in p_settingid integer) begin delete from setting where settingid=p_settingid; end select `name` from mysql.proc where db = 'your_db_name' and `type` = 'PROCEDURE' show procedure status; show create pro…