简体   繁体   English

在SELECT中使用CASE的SQL查询不起作用

[英]SQL query with CASE in SELECT doesn't work

I have this part of a larger complex query: 我有一个更大的复杂查询的这一部分:

SELECT SUM(pir.priceChange) AS CASE 
WHEN (SUM(pir.priceChange) > 0) THEN sellSum 
WHEN (SUM(pir.priceChange) < 0) THEN priceSum 
END

Whenever I try to pass it on to MySQL (MyISAM) via PDO, it throws me an exception: 每当我尝试通过PDO将其传递给MySQL(MyISAM)时,它会抛出异常:

Syntax error or access violation: 1064 You have an error in your SQL syntax; 语法错误或访问冲突:1064 SQL语法中有错误; check the manual that corresponds to your MySQL server version for the right syntax to use near '(SELECT SUM(pir.priceChange) AS CASE WHEN (SUM(pir.priceChange) > 0) THEN sellSu' at line 17 查看与您的MySQL服务器版本对应的手册,以便在'(SELECT SUM(pir.priceChange)AS CASE WHEN(SUM(pir.priceChange)> 0)附近使用正确的语法。然后在第17行使用sellSu'

I imagine it has something to do with the fact that I'm trying to use a CASE statement incorrectly. 我想这与我试图错误地使用CASE语句这一事实有关。 Would really like to know what's exactly wrong, thanks in advance. 真的很想知道出了什么问题,提前谢谢。

EDIT: My full query (edited without any cases): 编辑:我的完整查询(无任何情况编辑):

SELECT  pi.id AS id,
pi.type AS type,
pi.parValue AS rating,
pi.duration AS time,
countAmt.amt AS amtSold,
IFNULL(pii.pChange,
0) AS priceTotal,
0) AS costTotal,
IFNULL(pii.selfPrice,
0) AS costPrice,
(IFNULL(pii.sellSum,
0) - IFNULL(pii.selfPrice,
0)) AS profit,
countClose.amtClosed AS amtClosed
FROM salon.paymentInstrument as pi
(SELECT SUM(pir.priceChange) AS pChange,
SUM(pir.costChange) AS cChange,
(IFNULL(pir.priceChange,
0) - IFNULL(pir.costChange,
0)) AS selfPrice,
pii.paymentInstrumentID
FROM salon.paymentInstrumentRegister as pir
JOIN salon.paymentInstrumentItem as pii ON pir.paymentInstrumentItemID = pii.id
WHERE pir.date >= '2014-04-11'
AND pir.date <= '2014-04-25'
GROUP BY pii.paymentInstrumentID 
) as pii
(SELECT pii.paymentInstrumentID,
COUNT(*) AS amtClosed
FROM salon.paymentInstrumentItem as pii
WHERE pii.annulTime >= 2014-04-11
AND pii.annulTime <= 2014-04-25
AND pii.status <> "active"
GROUP BY pii.paymentInstrumentID 
) as countClose
(SELECT pii.paymentInstrumentID,
COUNT(*) AS amt
FROM salon.paymentInstrumentItem as pii
WHERE pii.startTime >= 2014-04-11
AND pii.startTime <= 2014-04-25
GROUP BY pii.paymentInstrumentID 
) as countAmt

Sorry for improper formatting, it's generated dynamically with PHP. 抱歉格式不正确,它是用PHP动态生成的。 I have a feeling i'm making a mistake somewhere else in the query. 我有一种感觉,我在查询中的其他地方犯了一个错误。

Try this way: 试试这种方式:

SELECT CASE WHEN SUM(pir.priceChange)>0 THEN SUM(pir.priceChange) END as SumPrice,
       CASE WHEN SUM(pir.priceChange)<0 THEN SUM(pir.priceChange) END as priceSum
FROM TableName

An example in SQL Fiddle . SQL Fiddle中的一个例子。

Try this: 尝试这个:

SELECT CASE 
WHEN (SUM(pir.priceChange) > 0) THEN sellSum 
WHEN (SUM(pir.priceChange) < 0) THEN priceSum 
END

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM