mysql父参数传入子查询_无法使用子查询传递Mysql过程中的参数

我试图创建我认为是一个相当简单的过程调用列名称的参数.

这是我创建的程序:

CREATE DEFINER=`root`@`%` PROCEDURE `test`(in col varchar(225))

BEGIN

-- Column of Averages

DROP temporary TABLE IF EXISTS temp;

CREATE temporary TABLE IF NOT EXISTS temp AS

SELECT col,

Round(Avg(bcount), 0) AS `Average # of Loans`

FROM (SELECT col,

Count(borrower) AS bcount

FROM whatif_dataset

WHERE loan_lienposition = 'first'

GROUP BY col,

Month(Str_to_date(status_fundingdate, '%m/%d/%Y')),

Year(Str_to_date(status_fundingdate, '%m/%d/%Y')))AS dt

GROUP BY col;

END

但是,当我打电话给程序时,我只得到一条记录,即:

Col Average # of Loans

'Passed Parameter' 757

在我看来,参数没有正确传递. MYSQL中有一些限制,不允许我这样做吗?

当我使用特定列名称currentprocessor运行相同的查询时,这是所需的结果:

currentprocessor Average # of Loans

proc1 20

proc2 12

proc3 8

proc4 22

proc5 24

最佳答案 我能够通过使用准备好的声明来纠正这个问题

CREATE DEFINER=`root`@`%` PROCEDURE `test`(in col varchar(225))

BEGIN

-- Column of Averages

DROP temporary TABLE IF EXISTS temp;

SET @sql= CONCAT('SELECT ', col,',',

'Round(Avg(bcount), 0) AS `Average # of Loans`

FROM (SELECT ', col,',

Count(borrower) AS bcount

FROM whatif_dataset

WHERE loan_lienposition = ''first''

GROUP BY ', col,',

Month(Str_to_date(status_fundingdate, "%m/%d/%Y")),

Year(Str_to_date(status_fundingdate, "%m/%d/%Y")))AS dt

GROUP BY ', col);

PREPARE stmt FROM @sql;

EXECUTE stmt;

DEALLOCATE PREPARE stmt;

END

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值