这期内容当中小编将会给大家带来有关如何在MySQL中使用存储结构,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

1.新建两张数据表:student1, student2

新建student1

DROPTABLEIFEXISTSstudent1;CREATETABLEstudent1(idINTNOTNULLauto_increment,nameTEXT,ageINT,PRIMARYKEY(id));

新建student2

DROPTABLEIFEXISTSstudent2;CREATETABLEstudent2(idINTNOTNULLauto_increment,nameTEXT,ageINT,PRIMARYKEY(id));

2.向student1中新增数据

INSERTINTOstudent1(name,age)VALUES('xiaoming',18);INSERTINTOstudent1(name,age)VALUES('xiaohong',17);INSERTINTOstudent1(name,age)VALUES('xiaogang',19);INSERTINTOstudent1(name,age)VALUES('xiaoyu',18);INSERTINTOstudent1(name,age)VALUES('xiaohua',20);

实现功能说明

1.打印student1中的部分信息

2.把student1中的部分数据复制到student2中

3.传入参数作为限制条件,把student1中的部分数据复制到student2中

注意事项

在编写存储结构的时候,我们不能以分号(;)结束。因为我们的SQL语句就是以分号(;)结尾的。这里我们要修改一下存储结构的结束符号(&&)。

这里我们使用MySQL中的DELIMITER进行修改,并在存储结构创建完毕时,再改为分号(;)结束即可。

关于这一点在后面的例子中有所体现。在编写MySQL的触发器中,也会用到类似的情况。

使用方式

1.打印student1中的部分信息

---------------------------------------------------------------DROPPROCEDUREIFEXISTStest_pro1;---------------------------------------------------------------DELIMITER&&CREATEPROCEDUREtest_pro1()BEGINset@sentence='select*fromstudent1whereage<19;';preparestmtfrom@sentence;executestmt;deallocatepreparestmt;END&&DELIMITER;

2.复制表存储过程的编写(不带参数)

---------------------------------------------------------------DROPPROCEDUREIFEXISTStest_pro2;---------------------------------------------------------------DELIMITER&&createproceduretest_pro2()beginDECLAREstop_flagINTDEFAULT0;DECLAREs_nameTEXTdefault'';DECLAREs_ageINTdefault0;DECLAREcur1CURSORFOR(selectname,agefromstudent1whereage<19);DECLARECONTINUEHANDLERFORSQLSTATE'02000'SETstop_flag=1;opencur1;fetchcur1intos_name,s_age;whilestop_flag<>1DOinsertintostudent2(name,age)values(s_name,s_age);fetchcur1intos_name,s_age;endwhile;closecur1;end&&DELIMITER;

3.复制表存储过程的编写(带参数)

---------------------------------------------------------------DROPPROCEDUREIFEXISTStest_pro3;---------------------------------------------------------------DELIMITER&&createproceduretest_pro3(INp_ageINT)beginDECLAREstop_flagINTDEFAULT0;DECLAREs_nameTEXTdefault'';DECLAREs_ageINTdefault0;DECLAREcur1CURSORFOR(selectname,agefromstudent1whereage<p_age);DECLARECONTINUEHANDLERFORSQLSTATE'02000'SETstop_flag=1;opencur1;fetchcur1intos_name,s_age;whilestop_flag<>1DOinsertintostudent2(name,age)values(s_name,s_age);fetchcur1intos_name,s_age;endwhile;closecur1;end&&DELIMITER;

这里的SQLSTATE '02000'和NOT FOUND系统返回值是一样的。

4.使用方式

calltest_pro1();

or

calltest_pro1(123);

上述就是小编为大家分享的如何在MySQL中使用存储结构了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。