MYSQL : 1583 'IFNULL'
1583 - Incorrect parameters in the call to native function 'IFNULL'


DECLARE p_substoreid NVARCHAR(100);
DECLARE p_Fname NVARCHAR(100);
DECLARE p_name NVARCHAR(100);

DECLARE no_more_departments INTEGER DEFAULT 0;  

DECLARE Cursor__bigclass CURSOR FOR SELECT `name` FROM Tempdb__bigclass;    

DECLARE Cursor_thedate CURSOR FOR SELECT substoreid,Fname FROM Tempdb__thedate; 

DECLARE CONTINUE HANDLER FOR NOT FOUND
         SET no_more_departments=1;         
DROP TEMPORARY TABLE IF EXISTS Tempdb__hdnames;
DROP TEMPORARY TABLE IF EXISTS Tempdb__receive_report;
DROP TEMPORARY TABLE IF EXISTS Tempdb__thedate;
DROP TEMPORARY TABLE IF EXISTS Tempdb__tab;
DROP TEMPORARY TABLE IF EXISTS Tempdb__bigclass;

SET @v_sql= CONCAT('Create TEMPORARY Table Tempdb__hdnames(select substoreid as `name` from hotelid where substoreid in (', p_FdName,'))');
PREPARE stmt FROM @v_sql; 
EXECUTE stmt; 
DEALLOCATE PREPARE stmt;


SET @v_sql= CONCAT('Create TEMPORARY Table Tempdb__bigclass(SELECT id as `name` FROM home_class  GROUP BY `id` )');
PREPARE stmt FROM @v_sql; 
EXECUTE stmt; 
DEALLOCATE PREPARE stmt;

CREATE TEMPORARY TABLE Tempdb__receive_report(
    SELECT A.* , B.bname  AS Fname  FROM receive_report A
      LEFT JOIN  hotelid B ON A.substoreid=B.substoreid
     WHERE  A.the_date BETWEEN  p_StarDate  AND p_EndDate
      AND A.substoreid IN (SELECT `name` FROM Tempdb__hdnames)
       AND (A.name='房型统计' OR A.name='房类'));

CREATE TEMPORARY TABLE  Tempdb__thedate (SELECT substoreid,Fname FROM Tempdb__receive_report  GROUP BY substoreid,  Fname);



SET @tab_sql='Create TEMPORARY Table Tempdb__tab(rq NVARCHAR(100),Fname NVARCHAR(100),hjzfs FLOAT,hjczs FLOAT,hjzj FLOAT';
SET @where_sql = '';
SET @column_sql = '';
SET @select_column_sql = '';
OPEN Cursor__bigclass; 
REPEAT        
    FETCH Cursor__bigclass INTO p_name;   
    BEGIN
       IF NOT no_more_departments THEN
        SET @tab_sql= CONCAT(@tab_sql,',`C', p_name,'Czfs` FLOAT',',`C', p_name,'Cczs` FLOAT',',`C', p_name,'Czj` FLOAT'); 
        SET @column_sql = CONCAT(@column_sql,',`C', p_name,'Czfs`',',`C', p_name,'Cczs`',',`C', p_name,'Czj`');                 
        SET @where_sql = CONCAT(@where_sql,',IFNULL(SUM(CASE WHEN (id =''',p_name,''' and `name`=''房型统计'') THEN day_rooms END) ,0)'
        ,',IFNULL(SUM(CASE WHEN (id =''',p_name,''' and `name`=''房类'') THEN day_rooms END) ,0)'
        ,',IFNULL(SUM(CASE WHEN (id =''',p_name,''' and `name`=''房类'') THEN day_money END) ,0)');

        SET @select_column_sql = CONCAT(@select_column_sql,' 
        , IFNULL(C',p_name,'Czfs,0) as C',p_name,'Czfs, IFNULL(C',p_name,'Cczs,0) as C',p_name,'Cczs, IFNULL(C',p_name,'Czj,0) as C',p_name,'Czj
        ,CASE IFNULL(C',p_name,'Czfs,0) WHEN 0 THEN 0 ELSE IFNULL(C',p_name,'Cczs,0)/C',p_name,'Czfs END AS C',p_name,'Cczl
        ,CASE IFNULL(C',p_name,'Cczs,0) WHEN 0 THEN 0 ELSE IFNULL(C',p_name,'Czj,0)/C',p_name,'Cczs END AS C',p_name,'Cpjfj');

       END IF;

    END;



    UNTIL no_more_departments  END REPEAT;   
    CLOSE Cursor__bigclass;                    

    SET @tab_sql= CONCAT(@tab_sql,');');


PREPARE stmt FROM @tab_sql; 
EXECUTE stmt; 
DEALLOCATE PREPARE stmt;

SET no_more_departments = 0;


OPEN Cursor_thedate; 
REPEAT        
FETCH Cursor_thedate INTO  p_substoreid,p_Fname;     
  BEGIN 
    IF NOT no_more_departments THEN

        SET @execute_sql= CONCAT('INSERT INTO Tempdb__tab(rq,Fname,hjzfs,hjczs,hjzj'                
        ,@column_sql,') SELECT ''',IFNULL(p_substoreid,''),''',''',IFNULL(p_Fname,''),'''
        ,IFNULL(SUM(CASE WHEN (id =''总房数'' and `name`=''房型统计'') THEN day_rooms END),0)
        ,IFNULL(SUM(CASE WHEN (id =''合计'' and `name`=''房类'') THEN day_rooms END),0)
        ,IFNULL(SUM(CASE WHEN (id =''合计'' and `name`=''房类'') THEN day_money END),0)'
        ,@where_sql,' 
         FROM Tempdb__receive_report WHERE substoreid=',p_substoreid,';');
        PREPARE stmt FROM @execute_sql; 
        EXECUTE stmt; 
        DEALLOCATE PREPARE stmt; 

    END IF; 
END;

UNTIL no_more_departments  END REPEAT;   
    CLOSE Cursor_thedate;                    

SET @execute_sql= CONCAT('SELECT rq,Fname,hjzfs,hjczs,hjzj
         ,CASE IFNULL(hjzfs,0) WHEN 0 THEN 0 ELSE IFNULL(hjczs,0)/hjzfs END AS hjczl
         ,CASE IFNULL(hjczs,0) WHEN 0 THEN 0 ELSE IFNULL(hjzj,0)/hjczs END AS hjpjfj'
        ,@select_column_sql,' FROM Tempdb__tab ORDER BY rq;');

PREPARE stmt FROM @execute_sql; 
EXECUTE stmt; 
DEALLOCATE PREPARE stmt; 
END


    存储过程报错,求助,急急急!!!

2个回答

Incorrect parameters in the call to native function 'IFNULL'
你检查用这个函数的参数,它说这个参数不正确,具体程序里,你看看这个参数值是不是有问题,不是字符串或者null

u011126065
jasondyoung 回复shayne97: 具体程序里执行这里的结果,跟单独运行不一定一样。我看有很多地方用到ifnull,你先只用一个,而且语句写的简单点。在程序里验证
大约 2 年之前 回复
shayne97
shayne97 IFNULL 的作用是判断是否为空,然后替换吧,所以检查了很久没有找到原因来求助。然后,在另外一个库里面执行不会报错,想知道大概是什么位置的原因就好处理了。
大约 2 年之前 回复

错误信息明显指出 :是你在调用的时候报错了,错误的调用了IFNULL函数。
结合参数看下存储过程中,所有用到IFNULL函数的地方,一一排查。

shayne97
shayne97 IFNULL 的作用是判断是否为空,然后替换吧,所以检查了很久没有找到原因来求助。然后,在另外一个库里面执行不会报错,想知道大概是什么位置的原因就好处理了。
大约 2 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
mysql的ifnull语句不起作用
-
IBatis中查询数字的返回值类型问题
-
mongodb有没有类似mysql的ifnull,oracle的nvl,这样的涵数或功能
-
mysql视图问题
-
如何把下面的mysql语句转化为oracle语句 ?
-
hibernate使用select ifnull报错但是在mysql直接运行没问题
-
mysql 5.6 关于一个时间字段的数据更新引发的sql异常
-
ifnull 在该字段为空时, 如何根据另一张表的规则来动态填充?
-
ifnull的相关问题解答
-
VS2010+MYSQL 存儲過程調用出錯
-
Oracle 改 mysql 报错
-
Mysql数据库 sql 取当前记录的某一字段的值
-
sql查询时case when XXX is not null then XXX else 0 end 和 ifnull(XXX,0)的区别在哪?
-
Mysql的关联查询语句查询优化
-
mysql导入.sql文件的问题
-
mysql存储过程循环只执行一次
-
MySql的一个查询问题
-
查询商品信息包含销量及销售总额信息?
-
mysql 、spring的jdbctemplete的问题
-
Linux文件操作高频使用命令
文章目录0.新建操作:1.查看操作2.删除操作3.复制操作4.移动操作:5.重命名操作:6.解压压缩操作 0.新建操作: mkdir abc #新建一个文件夹 touch abc.sh #新建一个文件 1.查看操作 查看目录: ll #显示目录文件详细信息 查看文件内容: cat|head|tail命令 cat abc.txt #查看abc的内容 head -5 abc.txt #...
程序员实用工具网站
目录 1、搜索引擎 2、PPT 3、图片操作 4、文件共享 5、应届生招聘 6、程序员面试题库 7、办公、开发软件 8、高清图片、视频素材网站 9、项目开源 10、算法 11、在线工具宝典大全 程序员开发需要具备良好的信息检索能力,为了备忘(收藏夹真是满了),将开发过程中常用的网站进行整理。 1、搜索引擎 1.1、秘迹搜索 一款无敌有良心、无敌安全的搜索引擎,不会收...
史上最详细的IDEA优雅整合Maven+SSM框架(详细思路+附带源码)
网上很多整合SSM博客文章并不能让初探ssm的同学思路完全的清晰,可以试着关掉整合教程,摇两下头骨,哈一大口气,就在万事具备的时候,开整,这个时候你可能思路全无 ~中招了咩~ ,还有一些同学依旧在使用eclipse或者Myeclipse开发,我想对这些朋友说IDEA 的编译速度很快,人生苦短,来不及解释了,直接上手idea吧。这篇文章每一步搭建过程都测试过了,应该不会有什么差错。本文章还有个比较优秀的特点,就是idea的使用,基本上关于idea的操作都算是比较详细的,所以不用太担心不会撸idea!最后,本文
我花了一夜用数据结构给女朋友写个H5走迷宫游戏
起因 又到深夜了,我按照以往在csdn和公众号写着数据结构!这占用了我大量的时间!我的超越妹妹严重缺乏陪伴而 怨气满满! 而女朋友时常埋怨,认为数据结构这么抽象难懂的东西没啥作用,常会问道:天天写这玩意,有啥作用。而我答道:能干事情多了,比如写个迷宫小游戏啥的! 当我码完字准备睡觉时:写不好别睡觉! 分析 如果用数据结构与算法造出东西来呢? ...
BMP、GIF、TIFF、PNG、JPG和SVG格式图像的特点
目录 1、BMP格式图像 2、GIF格式图像 3、TIFF格式图像 4、PNG格式图像 5、JPG格式图像 6、SVG格式图像 7、总结 7.1、有损vs无损 7.2、索引色vs直接色 7.3、点阵图vs矢量图 7.4、总结 一张图片可以储存为多种格式,为什么有的几十KB,有的几百MB,有的静止不动,有的是好几个画面循环播放?在项目开发的过程中经常会读取或保存图像...
高级软件工程师教会我的那些事儿
【CSDN编者按】以人为鉴,可明得失。对于新手程序员来说,面对复杂的开发需求很容易因为经验不足或技术不够娴熟等原因而踩坑。本文的作者表示:坐在高级软件工程师旁边工作或许可以事半功倍!长达一年的观察学习,他收获了包括编写代码、测试、设计、部署以及监控的一系列的长足进步。 声明:本文已获作者翻译授权,原文(https://neilkakkar.com/things-I-learnt-from-...
nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件
文章目录前言一、nginx简介1. 什么是 nginx 和可以做什么事情2.Nginx 作为 web 服务器3. 正向代理4. 反向代理5. 动静分离6.动静分离二、Nginx 的安装三、 Nginx 的常用命令和配置文件四、 Nginx 配置实例 1 反向代理五、 Nginx 配置实例 2 负载均衡六、 Nginx 配置实例 3 动静分离七、 Nginx 的高可用集群 前言 一、nginx简介...
MySQL数据库—SQL汇总
一、准备 下文整理常见SQL语句的用法,使用MySQL5.7测试,参考了尚硅谷MySQL教程及用例。用例sql: 链接: https://pan.baidu.com/s/1tb3-12MRNFjV8drFlN6wzg&shfl=sharepset 密码: fc2h 为了方便查阅可从右侧目录快速索引 二、DQL(Data Query Language)数据查询语言 1、语句顺序 书写顺序...
黑客入门,从HTB开始
Hack the box 是国外的一个靶机平台,里面的靶机包含多种系统类型,并且里面可以利用的漏洞类型多种多样,有很多靶机其实非常贴近实战情景。因此 HTB 是一个很好的学习渗透测试靶场。 之前在 HTB 也玩过一些机器。里面的机器难度有好几个档次,insane 难度的一般都是极其困难的,这种机器一般让我对着大神的 Writeup 我可能都没有办法复现出来。之前也有在公众号上分享过几篇 H...
动画:用动画给女朋友讲解 TCP 四次分手过程
作者 | 小鹿 来源 | 公众号:小鹿动画学编程 写在前边 大家好,我们又见面了,做为一个业余的动画师,上次的用动画的形式讲解 TCP 三次握手过程再各大平台收到了广大读者的喜爱,说文章有趣、有货、有内容,也受到了很多读者的关注。很多读者留言说什么时候用动画讲一讲 TCP 四次挥手的过程,为了应大家的要求,今天我们就生动有趣的用动画给大家分享 TCP 四次挥手(分手)过程。 动画:用动画给...
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
SQL基本语法入门 看这里就够了
SQL执行顺序 第一步:执行FROM 第二步:WHERE条件过滤 第三步:GROUP BY 分组 第四步:执行SELECT 投影列 第五步:HAVING条件过滤 第六步:执行ORDER BY排序 一、创建、删除库 -- 创建新数据库 CREATE DATABASE 数据库名; -- 删除数据库 DROP DATABASE 数据库名; 二、增加 1、添加列名、设置主键、设...
如何优化MySQL千万级大表,我写了6000字的解读
这是学习笔记的第2138篇文章 千万级大表如何优化,这是一个很有技术含量的问题,通常我们的直觉思维都会跳转到拆分或者数据分区,在此我想做一些补充和梳理,想和大家做一些这方面的经验总结,也欢迎大家提出建议。 从一开始脑海里开始也是火光四现,到不断的自我批评,后来也参考了一些团队的经验,我整理了下面的大纲内容。 既然要吃透这个问题,我们势必要回到本源,我把这个...
面试最后一问:你有什么问题想问我吗?
尽管,我们之前分享了这么多关于面试的主题: 高薪必备的一些Spring Boot高级面试题 面试必问:设计模式遵循的面向对象设计原则! 面试必问:怎么保证缓存与数据库的双写一致性? 27道高频Spring面试题,你能答对几个? 唠唠面试常问的:面向对象六大原则 一文高效图解二叉树面试题 Java面试中最高频的那20%知识点是什么? 百度面试题:求数组最大值 ... 然而,最后这个90%可见...
python 程序员进阶之路:从新手到高手的100个模块
在知乎和CSDN的圈子里,经常看到、听到一些 python 初学者说,学完基础语法后,不知道该学什么,学了也不知道怎么用,一脸的茫然。近日,CSDN的公众号推送了一篇博客,题目叫做《迷思:Python 学到什么程度可以面试工作?》,真实反映了 python 程序员在成长过程中的一些困惑。
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch, ...
Linux/C/C++ 不可错过的好书
来源:公众号【编程珠玑】 作者:守望先生 ID:shouwangxiansheng 前言 经常有读者让我推荐书籍,这次我就把我私藏的计算机书单分享给你们!不过由于时间匆忙,不会进行更加详细的介绍。 声明 由于每个人的情况不一样,推荐的书并不一定适合你,也不一定适合当前阶段的你,有的书籍可能存在内容重复,所以根据自己的阶段情况进行选择即可。虽说如此,以下书单中提单的书均为优质书籍。...
计算机处理器基础原理笔记
一、CPU指令电路 1. 计算机每执行一条指令的过程,可以分解成这样几个步骤。 (1)Fetch(取得指令),也就是从PC寄存器里找到对应的指令地址,根据指令地址从内存里把具体的指令,加载到指令寄存器中,然后把PC寄存器自增,在未来执行下一条指令。 (2)Decode(指令译码),也就是根据指令寄存器里面的指令,解析成要进行什么样的操作,是MIPS指令集的R、I、J中哪一种指令,具体要操作哪...
单点登录(SSO)
一、SSO(单点登录)介绍 SSO英文全称Single SignOn,单点登录。SSO是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。它包括可以将这次主要的登录映射到其他应用中用于同一个用户的登录的机制。它是目前比较流行的企业业务整合的解决方案之一。 实现机制 当用户第一次访问应用系统1的时候,因为还没有登录,会被引导到认证系统中进行登录;根据用户提供的登录信息,认证...
漫话:什么是 https ?这应该是全网把 https 讲的最好的一篇文章了
今天这篇文章,讲通过对话的形式,让你由浅入深着知道,为什么 Https 是安全的。 一、对称加密 一禅:在每次发送真实数据之前,服务器先生成一把密钥,然后先把密钥传输给客户端。之后服务器给客户端发送真实数据的时候,会用这把密钥对数据进行加密,客户端收到加密数据之后,用刚才收到的密钥进行解密。如图: 当然,如果客户端要给服务器发送数据,也是采用这把密钥来加密,这里为了方便,我采用单方向...
HTML CSS整理笔记
常见字体单位: 1.em 移动端常用的字体尺寸单位,说白em就相当于“倍”,比如设置当前的div的字体大小为1.5em,则当前的div的字体大小为:当前div继承的字体大小*1.5。 但当div进行嵌套时,em始终按当前div继承的字体大小来缩放。 2.rem r是root的意思,即相对于根节点html的font-size进行缩放,当有嵌套关系时,嵌套关系的元素的字体大小始终按照根节点的字体大小...
相关热词 c#多人合作开发项目策略 c# cad 坐标转换 c# 窗口内运行word c#线程睡眠 c# 静默打开打印机 c#获取当前路径的上一级 c# 去除线条 c# 取整倍数 c#窗体最大化控件不变 c# 程序更新程序案例