ColdFusion 2016和存储过程抛出无效字符错误

时间:2017-05-11 20:33:57

标签: db2 coldfusion-2016

我在CF 2016安装中尝试现有代码...我收到此错误

" [Macromedia] [DB2 JDBC Driver] [DB2] ILLEGAL SYMBOL =;有效符号是......"

标识的行是存储过程调用的参数,如下所示:

<cfstoredproc datasource="#application.dsn#" procedure="LIVE.STOPS">
    <cfprocparam type="In" cfsqltype="CF_SQL_BIGINT" dbvarname="STOPID" value="#val( variables.procstopid )#" null="no">
    <cfprocparam type="In" cfsqltype="CF_SQL_INTEGER" dbvarname="TRIPID" value="#val( url.tripId )#" null="no">
</cfstoredproc>

我找不到任何关于存储过程标签变化的提及 - 也许是DB2驱动程序?我正在寻找任何意见。感谢。

其他信息; Windows10,Apache2.4,与DB2 v10的连接。

@pendo,这是存储过程 - 应该注意的是我缩写了一些sql,但是SP工作并且在运行CF10的应用程序中已经很长时间了。

CREATE OR REPLACE PROCEDURE LIVE.STOP(
    IN stopId BIGINT DEFAULT 0,
    IN tripId INTEGER DEFAULT 0
) LANGUAGE SQL

BEGIN

DECLARE updateTripId INTEGER DEFAULT 0;
DECLARE minStopId BIGINT DEFAULT 0;
DECLARE maxStopId BIGINT DEFAULT 0;

DECLARE TripSearch_cursor CURSOR FOR 
    SELECT s1.fkTripsId
    FROM live.paymentsTripsStops s1
    JOIN  live.Trips t ON s1.fkTripsId = t.Id
    WHERE s1.fkStopsId = stopId 
    FETCH FIRST 1 ROWS ONLY;

DECLARE minMaxStop_cursor CURSOR FOR 
    SELECT
       COALESCE(
           (
                SELECT s.Id
                FROM  live.Stops s
                JOIN  live.Trips t ON s.fkTripsId = t.Id
                ORDER BY s.Sequence
                FETCH FIRST 1 ROWS ONLY
           ),
           0
       ) AS firstStopId,
       COALESCE(
           (
               SELECT s.Id
                FROM  live.Stops s
                JOIN  live.Trips t ON s.fkTripsId = t.Id
                ORDER BY s.Sequence DESC
                FETCH FIRST 1 ROWS ONLY
           ),
           0
       ) AS lastStopId
    FROM   live.Trips t
    WHERE  t.Id = updateTripId 
    FETCH FIRST 1 ROWS ONLY;

IF TripId > 0 
THEN SET updateTripId = TripId;
ELSE OPEN TripSearch_cursor;
    FETCH FROM TripSearch_cursor INTO updateTripId;
CLOSE TripSearch_cursor;
END IF;

IF updateTripId > 0 
THEN OPEN minMaxStop_cursor;
    FETCH FROM minMaxStop_cursor INTO minStopId, maxStopId;
CLOSE minMaxStop_cursor;

UPDATE live.Trips
SET fkFirstStopId = minStopId,
    fkLastStopId = maxStopId
WHERE  intId = updateTripId;
END IF;

END

0 个答案:

没有答案