mysql设置了保存点为什么提示保存点不存在 mysql 存储过程无法保存_数据库

该存储过程在一开始设置参数时,有两个一个是id,一个是name。在运行该存储过程时,如果只输入一个参数,如下:

mysql设置了保存点为什么提示保存点不存在 mysql 存储过程无法保存_mysql_02

那么会报参数数量不一致的错误:

Procedure execution failed
1318 - Incorrect number of arguments for PROCEDURE test.proc1; expected 2, got 1

所以需要把参数中的name加上:

mysql设置了保存点为什么提示保存点不存在 mysql 存储过程无法保存_数据库_03

再次运行,还是有错误:

Procedure execution failed
1172 - Result consisted of more than one row

结果返回多行,这个问题产生的原因是:参数设置的错误,最好改成和相关表中字段名不一致的参数

如下图:

mysql设置了保存点为什么提示保存点不存在 mysql 存储过程无法保存_存储_04

再次运行,记得参数数量,还有一点要把参数的大小手动设置,在创建存储过程时,navicate只为参数设置类型,但是大小需要我们自己设置,否则在保存存储过程时会报错!,名字别写错:

mysql设置了保存点为什么提示保存点不存在 mysql 存储过程无法保存_mysql_05

运行结果:

mysql设置了保存点为什么提示保存点不存在 mysql 存储过程无法保存_sql_06

这样就可以了:)