利用navicat创建存储过程.触发器和使用游标的简单实例 标签: navicat存储过程触发器mysql游标 2013-08-03 21:34 15516人阅读 评论(1) 收藏 举报  分类: 数据库(3)  版权声明:本文为博主原创文章,未经博主允许不得转载.   目录(?)[+]   创建存储过程和触发器 1.建表 首先先建两张表(users表和number表),具体设计如下图: 2.存储过程 写一个存储过程,往users表中插入数据,创建过程如下: 代码如下: BEGIN #Routi…
MySQL存储过程  游标 如何在存储过程中使用MySQL游标来遍历SELECT语句返回的结果集 MySQL游标简介 要处理存储过程中的结果集,请使用游标.游标允许您迭代查询返回的一组行,并相应地处理每行. MySQL游标为只读,不可滚动和敏感. 只读:无法通过光标更新基础表中的数据. 不可滚动:只能按照SELECT语句确定的顺序获取行.不能以相反的顺序获取行. 此外,不能跳过行或跳转到结果集中的特定行. 敏感:有两种游标:敏感游标和不敏感游标.敏感游标指向实际数据,不敏感游标使用数据的临时副本…
create procedure my_procedure() -- 创建存储过程 begin -- 开始存储过程 declare my_id varchar(32); -- 自定义变量1 declare my_name varchar(50); -- 自定义变量2 DECLARE done INT DEFAULT FALSE; -- 自定义控制游标循环变量,默认false DECLARE My_Cursor CURSOR FOR ( SELECT id, name FROM t_people…
本人收集的,挺有用的 1. 利用游标循环更新.删除MemberAccount表中的数据 DECLARE My_Cursor CURSOR --定义游标 FOR (SELECT * FROM dbo.MemberAccount) --查出需要的集合放到游标中 OPEN My_Cursor; --打开游标 FETCH NEXT FROM My_Cursor ; --读取第一行数据 WHILE @@FETCH_STATUS = 0 BEGIN --UPDATE dbo.MemberAccount SE…
自己写的一个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…
一,有子节点的部门的子节点的排序,调用子存储过程 CREATE OR REPLACE PROCEDURE "PRO_INIT_SORT" AS CURSOR cur_department_all IS select * from tbl_department; VAR_COUNT NUMBER ; VAR_OUT_COUNT NUMBER := 0; BEGIN FOR department_row IN cur_department_all LOOP SELECT COUNT(1)…
将会用到的几个表 mysql> DESC products; +------------+--------------+------+-----+---------+----------------+ | Field      | Type         | Null | Key | Default | Extra          | +------------+--------------+------+-----+---------+----------------+ | prod_id…
<?php $dbtype = 'mysql'; $host = 'localhost'; $dbname = 'test'; $dsn = "$dbtype:host=$host;dbname=$dbname"; $user = 'root'; $password = 'root'; try{ $pdo = new PDO($dsn, $user, $password); } catch(PDOException $e) { echo $e->getMessage();…
游标 游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力. 使用步骤 声明一个游标: declare 游标名称 CURSOR for table;(这里的table可以是你查询出来的任意集合) 打开定义的游标:open 游标名称; 获得下一行数据:FETCH  游标名称 into field_1, field_2; 需要执行的语句(增删改查):这里视具体情况而定 释放游标:CLOSE 游标名称; 注:存储过程临时…
mysql 操作同样有循环语句操作,三种标准循环模式:while, loop,repeat, 外加一种非标准循环:goto [在c或c#中貌似出现过类型循环但是一般不建议用!] 一般格式为:delimiter // 定义结束符 drop procedure if exists wk; 假如存在则删除create procedure name([in | out | input] 参数) begin while-loop-repeat-mysql-code end // delimiter ; 还…