mysql 存储过程错误调试记录



mysql存储过程错误调试记录

公司平台在mysql数据库上运行,一些存储过程报错,调试过程痛苦,记录错误及解决办法,供参考。

调试环境:dbForge Studio for MySQL 6.1版本,试用版;

1、BIZ_GET_ORGAN_BY_CONDITION

问题1:提示递归调用错误,递归次数太多;根据业务设置,最大255;

[email protected]@max_sp_recursion_depth = 10;

常见如乱码造成导致条件失效,出现死循环;

问题2:变量的内容是乱码,数据库内容是中文,urt-8

declarevc_agency_type varchar(64) CHARACTER SET utf8;

定义变量时,需设置字符集;

问题3:存储过程参数传递中文,是乱码;定义参数同上;

2、BIZ_QUERY_USER_BY_CONDITION

问题1:row_count()返回-1

select
语句的返回值用FOUND_ROWS();row_count()一般是插入、修改、删除的影响行数;

问题2:mysql关于整数的除法

declare page_count int;

set page_count = 15 / 10 ;结果自动四舍五入为 2;

改用下面的语句:set page_count =FLOOR(result_count / page_size);

3、C3_BIZ_DATA_LIMIT

问题1:游标有记录,但是取值为空:游标语句中的变量不能和字段同名,且不要是关键字;

问题2:游标取不到值;

字段名称和变量名称一定不能相同;如果必须相同,给表加上别名进行区别;

问题3:out参数不能传值

修改成inout类型,存储过程共有三种类型:in out inout;

问题4:right函数改成subStr函数;

4、BIZ_CHANGER_ORG_PARENT_ID

问题1:mysql没有if not exists
语法,所以需要取总数,然后在判断行数量;

问题2:update不支持子查询问题;

update sys_org set leaftype = 1where 
id = (

selectorg_parent_id from sys_org where id = 变量

);

修改为:

update sys_org set leaftype = 1where 
id = (

select org_parent_id from

(select* from sys_org WHERE id = vc_source_id ) a

);

时间: 2024-08-02 07:00:25

mysql 存储过程错误调试记录的相关文章

MySQL 存储过程错误处理

MySQL  存储过程错误处理 如何使用MySQL处理程序来处理在存储过程中遇到的异常或错误. 当存储过程中发生错误时,重要的是适当处理它,例如:继续或退出当前代码块的执行,并发出有意义的错误消息. MySQL提供了一种简单的方法来定义处理从一般条件(如警告或异常)到特定条件(例如特定错误代码)的处理程序. 声明处理程序 要声明一个处理程序,您可以使用DECLARE HANDLER语句如下: DECLARE action HANDLER FOR condition_value statement

JDBC使用MySQL存储过程错误

JDBC连接执行 MySQL 存储过程报权限错误:User does not have access to metadata required to determine stored procedure parameter types. If rights can not be granted, 执行存储过程时,出现如下错误: java.sql.SQLException: User does not have access to metadata required to determine st

MySql存储过程的调试

写和调试存储过程比较好的工具是dbForge studio for mysql 校验其中临时表字段是否符合要求,在存储过程中动态为临时表添加字段约束,或者写个游标,把数据迭代出来,一个个判断.当游标迭代时发现错误,可以手动执行一条错误的语句(如insert into notExists values(1)),来终止存储过程. 但是以上加约束或者游标遍历,出现错误时,在Java调用端仅仅提示xxx not exists 或者 xxx should not be null 等错误,并没有提供具体在存

错误调试记录1

ports\os_cpu.c(5): error:  #130: expected a "{" ports\os_cpu.c:   extern void OSCtxSw(void); ports\os_cpu.c:   ^ ports\os_cpu.c(8): warning:  #12-D: parsing restarts here after previous syntax error ports\os_cpu.c:   { ports\os_cpu.c:   ^ 出现以上这类

oracle 存储过程最好的记录错误方式

当你的应用有调用存储过程,而节点有几十个或者上百个,找错是不是一个很麻烦的事情,这个时候,我建议写到数据库中,下面是我做的一个demo. 1. 建立错误日志记录表 drop table PUB_PROC_ERR_LOG purge; create table PUB_PROC_ERR_LOG ( LOG_ID      NUMBER, MODULE_NAME VARCHAR2(100), PROC_NAME   VARCHAR2(100), ERR_TIME    DATE, SQL_CODE

JAVA调用mysql存储过程noAccessToProcedureBodies错误

问题:在JAVA中调用MYSQL存储过程遇到以下报错: java.sql.SQLException: User does not have access to metadata required to determine stored procedure parameter types. If rights can not be granted, configure connection with "noAccessToProcedureBodies=true" to have dri

mysql存储过程出参入参,sqlserver很熟悉的一件事到mysql,捣鼓了大半天。记录一下提醒自己。勿看

create PROCEDURE myTestProcname(in score int ,out result varchar(100))BEGINIF score>60 THENset result='yes';ELSEset result='no';END if; END 调用 CALL myTestProcname(50,@result); select @result //为了看下出参结果 附带转来的一点语法 一.创建存储过程1.基本语法:create procedure sp_nam

mysql 存储过程的实现原理

一.描述 存储过程是一组可以完成特定功能的SQL语句集,经编译后存储在数据库中 statement语句(DDL.DML.导出及管理语句等).异常处理.流程控制二.创建存储过程 系统做语句分析,如果没有出现词.语法等的错误则存入系统表mysql.proc中三.调用存储过程1.编译 存储过程体中的语句集会被解析为一组指令集 存储过程的执行就是从该组指令集的第一个指令开始顺序执行 系统对存储过程的解析是以语句或结构为单位的,该部分处理在YACC中完成 注意:语句和指令之间并非一对一的对应关系 2.优化

当PHP遇到MySQL存储过程

1.MySQL存储过程 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它. 一个存储过程是一个可编程的函数,它在数据库中创建并保存.它可以有SQL语句和一些特殊的控制结构组成.当希望在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的.数据库中的存储过程可以看做是对编