免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4958 | 回复: 10

【讨论中】游标中如何使用in条件变量 [复制链接]

论坛徽章:
0
发表于 2012-11-29 15:54 |显示全部楼层
本帖最后由 cenalulu 于 2012-11-30 13:36 编辑

在存储过程中定义条件中使用了in 条件,可是没有什么返回,
如下定义in条件不用变量是可以的。
DECLARE cur_fm CURSOR FOR select FISCAL_WEEK,OPERATION,SUM(PRIME_PASS)/SUM(PRIME_TESTED),SUM(TOTAL_PASS)/SUM(TOTAL_TESTED) from WEEKLY where BUILD_GROUP in ('NEW','MRW') group by FISCAL_WEEK,OPERATION;

但用上变量后就不行了。
v_LIST是变量,通过参数传入存储过程。写入log 值为:('NEW','MRW','COO')。
DECLARE cur_fm CURSOR FOR select FISCAL_WEEK,OPERATION,SUM(PRIME_PASS)/SUM(PRIME_TESTED),SUM(TOTAL_PASS)/SUM(TOTAL_TESTED) from WEEKLY where BUILD_GROUP in v_LIST group by FISCAL_WEEK,OPERATION;

论坛徽章:
0
发表于 2012-11-29 20:39 |显示全部楼层
是否可以把整句sql定义成变量??

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
发表于 2012-11-30 09:16 |显示全部楼层
1. 你传入的 v_list 在 sql 里就只是“一个”字符串,所以 in 不了。
2. 可以,请搜索动态 sql 语句。

论坛徽章:
8
CU大牛徽章
日期:2013-09-18 15:20:48CU大牛徽章
日期:2013-09-18 15:20:58CU大牛徽章
日期:2013-09-18 15:21:06CU大牛徽章
日期:2013-09-18 15:21:12CU大牛徽章
日期:2013-09-18 15:21:17天秤座
日期:2013-10-30 14:01:03摩羯座
日期:2013-11-29 18:02:31luobin
日期:2016-06-17 17:46:36
发表于 2012-11-30 09:31 |显示全部楼层
@seesea2517
又跟高手学了一招。动态sql,还真不知道mysql有这玩意。好像也没太多这种需求

论坛徽章:
0
发表于 2012-11-30 09:58 |显示全部楼层
我需要用游标取回数据集,然后处理数据,不用游标的话怎么取回?可否给个例子?

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
发表于 2012-11-30 11:24 |显示全部楼层
回复 4# chinafenghao


    可说又学一招,但千万别加上高手……

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
发表于 2012-11-30 11:29 |显示全部楼层
回复 5# luiszhu


    动态sql也可以用游标。

论坛徽章:
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
发表于 2012-11-30 13:52 |显示全部楼层
回复 3# seesea2517


    指正一下错误,动态SQL是不允许出现在游标中的。
游标declare时,仅支持存储过程内的变量的替换。即,declare后的SQL必须是完整语法,不能是字符串的拼接。

摘录文档如下:具体见:http://dev.mysql.com/doc/refman/ ... red-statements.html

SQL syntax for prepared statements can be used within stored procedures, but not in stored functions or triggers. However, a cursor cannot be used for a dynamic statement that is prepared and executed with PREPARE and EXECUTE. The statement for a cursor is checked at cursor creation time, so the statement cannot be dynamic.


以下是test代码,是过不了编译的。报错如下:
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 'DECLARE receipt_cur cursor for @msql;
  1. DELIMITER $

  2. DROP PROCEDURE IF EXISTS `test`.`data-update-insert`$

  3. CREATE DEFINER=`root`@`%` PROCEDURE `data-update-insert`()
  4. LABEL: BEGIN
  5.     DECLARE iJobID INT;
  6.     DECLARE iGroupID INT;
  7.     DECLARE finished INT;
  8.        
  9. set @msql := 'select UserID from test.UserID';
  10. DECLARE receipt_cur cursor for @msql;

  11.             OPEN receipt_cur;
  12.         get_receipt: LOOP
  13.                 FETCH receipt_cur INTO iJobID,iGroupID;
  14.                 IF finished THEN
  15.                         LEAVE get_receipt;
  16.                 END IF;
  17.         select 1;

  18.         END LOOP get_receipt;
  19.         CLOSE receipt_cur;   
  20.     END$

  21. DELIMITER ;
复制代码

论坛徽章:
8
综合交流区版块每周发帖之星
日期:2015-12-02 15:03:53数据库技术版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-10-02 06:20:00IT运维版块每日发帖之星
日期:2015-09-14 06:20:00金牛座
日期:2014-10-10 11:23:34CU十二周年纪念徽章
日期:2013-10-24 15:41:34酉鸡
日期:2013-10-19 10:17:1315-16赛季CBA联赛之北京
日期:2017-03-06 15:12:44
发表于 2012-11-30 14:14 |显示全部楼层
大牛版主出现

论坛徽章:
93
2015年辞旧岁徽章
日期:2019-10-10 10:51:15CU大牛徽章
日期:2014-02-21 14:21:56CU十二周年纪念徽章
日期:2020-10-15 16:55:55CU大牛徽章
日期:2014-02-21 14:22:07羊年新春福章
日期:2019-10-10 10:51:39CU大牛徽章
日期:2019-10-10 10:55:38季节之章:春
日期:2020-10-15 16:57:40ChinaUnix元老
日期:2019-10-10 10:54:42季节之章:冬
日期:2019-10-10 10:57:17CU大牛徽章
日期:2014-02-21 14:22:52CU大牛徽章
日期:2014-03-13 10:40:30CU大牛徽章
日期:2014-02-21 14:23:15
发表于 2012-11-30 14:52 |显示全部楼层
回复 8# cenalulu


    感谢指出,我想当然了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP