简简单单储存过程――循环一个select结果集_MySQL
bitsCN.com
摘要:本文主要讲解了存储过程的创建、调用、以及游标的使用 ,相信掌握了游标 会对你有不错的帮助,有不足之处还请指教
导航 : 一、存储过程的创建及调用
二 、游标的使用
三、 示例
四、补充
说明:
1、用到的两个数据表:
from_data
to_data
2、示例需求 : 将表from_data 的select结果集循环插入到表 to_data;
伪代码: while 循环 select id ,name from_data
insert into to_data(id,name) value(from_data.id,from_data.name)
end
3、环境: mysql
一、存储过程的创建及调用
我们创建一个名叫 add_test的存储过程
1 、检查是否有 add_test
Sql代码
drop procedure if exists add_test;
2、创建
Sql代码
create procedure add_test()
(
#[in|out|inout] 参数 datatype
a int;
b int;
)
begin
#SQL 语句;
end;
3、调用
Sql代码
call add_test(1,2
);
以上就是基本的创建方法,注意已下几点:
1 、在建立和调用时,add_test后面的“()”是必须的
2、MySQL 存储过程参数如果不显式指定“in”、“out”、“inout”,则默认为“in”,并且参数不能指定默认值 。
3、包含多条 SQL 语句时,需要 begin end 关键字,在begin end里面的每条语句的末尾,都要加上分号 “;”
4、在begin end里面声明变量,使用关键字 DECLARE ,如:
Sql代码
begin
#声明一个name变量,类型是varchar(记得分号)
name varchar(32);
end;
二 、游标的使用
1、定义游标
Sql代码
/*
定义游标的关键字:CURSOR。
定义游标cursor_name,
游标cursor_name当前指针的记录
是一个表from_data的多行结果集
*/
DECLARE cursor_name CURSOR FOR select id,name
from from_data;
2、打开游标
Sql代码
#关键字:OPEN
OPEN cursor_name;
3、 获取游标
Sql代码
#声明两个变量
DECLARE a int
;
DECLARE b varchar(32)
;
/*
FETCH 获取游标当前指针的记录,并传给指定变量 a 、b
*/
FETCH cursor_name INTO a,b;
注意:(1、此处很重要,我们在后面的循环例子中会详细讲解如何用,
(2、注意变量数必须与MySQL游标返回的字段数以及类型一致,请看2,3步的标红处,
a的类型对应 id,b类型对应name
4、关闭游标
Sql代码
CLOSE cursor_name ;
以上就是游标的常见使用方法,关键的部分我已在每一步中说明,就不在多说了,现在我们看下例子:
三、示例
Sql代码
drop procedure if exists add_test;
# 创建存储过程 add_test
CREATE PROCEDURE add_test()
BEGIN
#定义 变量
DECLARE a int;
DECLARE b VARCHAR(30);
#此变可有可无,为了给个该存储函数执行成功后给个提示,运行下便知道
DECLARE str VARCHAR(300);
DECLARE x int;
#这个用于处理游标到达最后一行的情况
DECLARE bitsCN.com

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds



L'article discute de l'utilisation de l'instruction ALTER TABLE de MySQL pour modifier les tables, notamment en ajoutant / abandon les colonnes, en renommant des tables / colonnes et en modifiant les types de données de colonne.

L'article discute de la configuration du cryptage SSL / TLS pour MySQL, y compris la génération et la vérification de certificat. Le problème principal est d'utiliser les implications de sécurité des certificats auto-signés. [Compte de caractère: 159]

L'article traite des stratégies pour gérer de grands ensembles de données dans MySQL, y compris le partitionnement, la rupture, l'indexation et l'optimisation des requêtes.

L'article traite des outils de GUI MySQL populaires comme MySQL Workbench et PhpMyAdmin, en comparant leurs fonctionnalités et leur pertinence pour les débutants et les utilisateurs avancés. [159 caractères]

L'article discute de la suppression des tables dans MySQL en utilisant l'instruction TABLE DROP, mettant l'accent sur les précautions et les risques. Il souligne que l'action est irréversible sans sauvegardes, détaillant les méthodes de récupération et les risques potentiels de l'environnement de production.

L'article discute de l'utilisation de clés étrangères pour représenter les relations dans les bases de données, en se concentrant sur les meilleures pratiques, l'intégrité des données et les pièges communs à éviter.

L'article discute de la création d'index sur les colonnes JSON dans diverses bases de données comme PostgreSQL, MySQL et MongoDB pour améliorer les performances de la requête. Il explique la syntaxe et les avantages de l'indexation des chemins JSON spécifiques et répertorie les systèmes de base de données pris en charge.

L'article discute de la sécurisation MySQL contre l'injection SQL et les attaques brutales à l'aide de déclarations préparées, de validation des entrées et de politiques de mot de passe solides (159 caractères)
