ホームページ >データベース >mysql チュートリアル >MySQL ストアド プロシージャの高度な SQL ステートメントの概要
この記事では、mysql に関する関連知識を紹介し、主にストアド プロシージャの高度な SQL ステートメントに関する関連内容を紹介します。一緒に見ていきましょう。皆様のお役に立てれば幸いです。
推奨学習: mysql ビデオ チュートリアル
ストアド プロシージャは、特定の機能を実行するために設計された一連の SQL ステートメントです。
ストアドプロシージャの利用では、よく使うタスクや複雑なタスクをあらかじめSQL文で記述し、指定した名前で格納し、コンパイル・最適化してデータベースサーバーに格納します。このストアド プロシージャを使用する必要がある場合は、それを呼び出すだけです。ストアド プロシージャは、従来の SQL よりも高速かつ効率的に実行されます。
delimiter $$ #将语句的结束符号从分号;临时改为两个$$(可以自定义) create procedure proc () #创建存储过程,过程名为proc,不带参数 -> begin #过程体以关键字begin开始 -> select * from store_info; #过程体语句 -> end $$ #过程体以关键字end结束 delimiter ; #将语句的结束符号恢复为分号例:
delimiter $$create procedure proc01 ()-> bengin -> create table student(id int,name char(10),age int);-> insert into student values(1,'zhangsan',18);-> insert into student values(2,'lisi',18);-> select * from student;-> end $$delimiter ;
call proc; #调用存储过程 show create procedure [数据库.]存储过程名; #查看某个存储过程的具体信息 show create procedure proc; show create procedure proc\G show procedure status [like '%proc%'] \G例:
call proc01; show create procedure proc01; show create procedure proc01\G #查看存储过程的具体信息 show procedure status like '%Proc01%'\G
#存储过程内容的修改方法是通过删除原有存储过程,之后再以相同的名称创建新的存储过程。 drop procedure if exists proc; #仅当存在时删除,不添加If EXISTS 时,如果指定的过程不存在,则产生一个错误。例:
drop procedure if exists proc01;
delimiter $$create procedure proc2(in stuname char(20)) #参数为stuname,数据类型一定要与下面的where语句后字段的数据类型相同-> begin -> select * from student where name = stuname;-> end $$delimiter ;call proc2('zhangsan'); #调用存储过程,并传入参数‘zhangsan’4. ストアド プロシージャの制御ステートメント
delimiter $$ create procedure proc03(in innum int) #创建存储过程proc03,参数为innum,类型为int -> begin -> declare var int; #定义变量var为int类型 -> set var=innum*2; #变量var的值等于传入的参数值乘2 -> if var>=10 then #当var的值大于10时,id值会加1,否则减1 -> update ss set id=id+1; -> else -> update ss set id=id-1; -> end if; -> end $$ delimiter ; call proc03(8); #调用存储过程,并传入参数8 call proc03(3); #调用存储过程,并传入参数3
delimiter $$ #修改默认结束符为$$ create procedure proc05() #创建存储过程proc04 -> begin #过程体以关键字begin开始 -> declare var int(10); #定义变量var为int类型 -> set var=0; #var的起始值为0 -> while var insert into ss values(var); -> set var=var+1; #每次循环后var值自增1 -> end while; #结束while循环 -> end $$ #创建存储过程结束 delimiter ; #重新修改默认结束符为原始的; call proc05; #调用存储过程proc04
mysql ビデオ チュートリアル
以上がMySQL ストアド プロシージャの高度な SQL ステートメントの概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。