以下のUPDATEクエリは、Workbenchにスローすると正常に機能しますが、phpを介して実行しようとすると、何も実行されません。何か案は?
varchar(100)とFloatとしてテーブルの構造を試しTURNOVERSCORE
ましたが、table1.itemとt2.itemが主キーです。
mysql_errorの使用時にエラーを提供します:
SQL構文にエラーがあります。MySQLサーバーのバージョンに対応するマニュアルで、'UPDATE table1 JOIN(SELECT count(*)as cnt、ITEM FROM table2WHERE'の2行目付近で使用する正しい構文を確認してください。
$con = mysql_connect("localhost","username","pw");
$turnoverquery = "UPDATE table1
JOIN (SELECT count(*) as cnt, item FROM table2 WHERE table2.TRANS_DATE BETWEEN DATE_SUB(CURDATE(), INTERVAL 365 DAY) AND CURDATE() GROUP BY item) t2
ON table1.item = t2.item
SET table1.TURNOVERSCORE=CASE
WHEN t2.cnt/12 < 1 AND table1.CAT = 'E' THEN .05
WHEN t2.cnt/12 >= 1 AND t2.cnt/12 < 4 AND table1.CAT = 'E' THEN .5
WHEN (t2.cnt/12) >= 4 AND table1.CAT = 'E' THEN 1
WHEN (t2.cnt/12) <= 5 AND table1.CAT != 'E' THEN .05
WHEN (t2.cnt/12) >= 6 AND (t2.cnt/12) < 11 AND table1.CAT != 'E' THEN .25
WHEN (t2.cnt/12) >= 11 AND (t2.cnt/12) < 21 AND table1.CAT != 'E' THEN .5
WHEN (t2.cnt/12) >= 21 AND table1.CAT != 'E' THEN 1 END";
mysql_query($turnoverquery);