免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1593 | 回复: 3
打印 上一主题 下一主题

求助一个mysql存储过程的问题5.1 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-04-28 16:23 |只看该作者 |倒序浏览
我在mysql中创建一个存储过程
表中有一个 (日期 datetime) 字段,要取某个时间段的第a到b条,如'2012-04-20‘到'2012-04-25'时间段的第50到100条.
以下是建立存储过程语句
create procedure pro_select_sitedata
        (in P_start_time datetime,
         in P_end_time datetime,
        in a integer,
        in b integer)
BEGIN       
        select * from result
                where 日期 between P_start_time and P_end_time
                limit a,b;
END
它提示错误:ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that
corresponds to your MySQL server version for the right syntax to use near 'a,b;
可是我如果把a,b换成常量
create procedure pro_select_sitedata
        (in P_start_time datetime,
         in P_end_time datetime,
        in a integer,
        in b integer)
BEGIN       
        select * from result
                where 日期 between P_start_time and P_end_time
                limit 50,50;END
就没问题了,请教一下为什么?谢谢

论坛徽章:
0
2
发表于 2012-04-28 17:16
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
3 [报告]
发表于 2012-04-28 18:18 |只看该作者
本帖最后由 飞鸿无痕 于 2012-04-28 18:30 编辑

mysql  存储过程中的limit不能直接使用变量,要通过?号的形式!
给你改一下,看看能不能跑:
  1. DELIMITER //
  2. DROP PROCEDURE IF EXISTS pro_select_sitedata //
  3. CREATE PROCEDURE pro_select_sitedata
  4.         (IN P_start_time DATETIME,
  5.          IN P_end_time DATETIME,
  6.         IN a INTEGER,
  7.         IN b INTEGER)
  8. BEGIN      
  9.        SET @sql1='select * from result
  10.                 where 日期 between P_start_time and P_end_time
  11.                 limit ?,?;';
  12.        SET @a=a;
  13.        SET @b=b;
  14.        PREPARE stmt FROM @sql1;
  15.        EXECUTE stmt USING @a,@b;
  16.        DEALLOCATE PREPARE stmt;
  17. END
  18. //
  19. DELIMITER ;
复制代码

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
4 [报告]
发表于 2012-05-01 16:20 |只看该作者
楼上正解,limit N, M中的N和M对于MySQL来说属于不可变量替代的成分,一定要用变量的话只用于prepare + execute了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP