关键字 IF 不是预期的
Keyword IF not expected
我有以下内联 SQL 代码,运行ning 在 AS400 上。 IF 出乎意料,但我不明白为什么。我想要做的是构建一个存储过程来更新或插入 table 行。下面显示的代码是内联的,以确保我的逻辑是正确的。
我尝试了多种不同的方法,包括 IF EXISTS、CASE、SET @COUNT = SELECT COUNT(*)。我继续 运行 进入奇怪的错误。
在下面显示的代码中,我在点击 IF 语句时失败了。
CREATE OR REPLACE VARIABLE IN_LOC CHAR(02);
CREATE OR REPLACE VARIABLE IN_MCO CHAR(02);
CREATE OR REPLACE VARIABLE IN_SYMBOL CHAR(03);
CREATE OR REPLACE VARIABLE IN_POLICYNUM CHAR(07);
CREATE OR REPLACE VARIABLE IN_MODULE CHAR(02);
CREATE OR REPLACE VARIABLE IN_RISKLOC CHAR(05);
CREATE OR REPLACE VARIABLE IN_PRCCLASS VARCHAR(05);
CREATE OR REPLACE VARIABLE IN_PRCTER VARCHAR(03);
CREATE OR REPLACE VARIABLE IN_MESSAGE CHAR(02);
SET IN_LOC='00';
SET IN_MCO='01';
SET IN_SYMBOL='CPP';
SET IN_POLICYNUM='0003748';
SET IN_MODULE='00';
SET IN_RISKLOC='00003';
SET IN_PRCCLASS='09';
SET IN_PRCTER='1';
SET IN_MESSAGE='NOT FOUND FOR ODD PROGRAMMING';
UPDATE BASPPRC01
SET PRCCLASS=IN_PRCCLASS,PRCTER=IN_PRCTER,MESSAGE=IN_MESSAGE
WHERE CAST(IN_LOC||IN_MCO||IN_SYMBOL||IN_POLICYNUM||IN_MODULE||IN_RISKLOC AS CHAR(21))
= CAST(LOCATION||MASTERCO||SYMBOL||POLICYNUM||MODULE||RISKLOC AS CHAR(21)) ;
IF @@ROWCOUNT = 0
BEGIN
INSERT INTO BASPPRC01
(LOCATION,MASTERCO,SYMBOL,POLICYNUM,MODULE,RISKLOC,PRCCLASS,PRCTER,MESSAGE)
VALUES
(IN_LOC
, IN_MCO
, IN_SYMBOL
, IN_POLICYNUM
, IN_MODULE
, IN_RISKLOC
, IN_PRCCLASS
, IN_PRCTER
, IN_MESSAGE ) ;
END
COMMIT TRANSACTION ;
你应该显示你得到的错误...
具有以下内容:
CREATE OR REPLACE PROCEDURE myproc ()
LANGUAGE SQL
BEGIN
UPDATE BASPPRC01
SET PRCCLASS=IN_PRCCLASS,PRCTER=IN_PRCTER,MESSAGE=IN_MESSAGE
WHERE CAST(IN_LOC||IN_MCO||IN_SYMBOL||IN_POLICYNUM||IN_MODULE||IN_RISKLOC AS CHAR(21))
= CAST(LOCATION||MASTERCO||SYMBOL||POLICYNUM||MODULE||RISKLOC AS CHAR(21)) ;
IF @@ROWCOUNT = 0
BEGIN
INSERT INTO BASPPRC01
(LOCATION,MASTERCO,SYMBOL,POLICYNUM,MODULE,RISKLOC,PRCCLASS,PRCTER,MESSAGE)
VALUES
(IN_LOC
, IN_MCO
, IN_SYMBOL
, IN_POLICYNUM
, IN_MODULE
, IN_RISKLOC
, IN_PRCCLASS
, IN_PRCTER
, IN_MESSAGE ) ;
END
COMMIT TRANSACTION ;
END;
我得到[SQL0199] Keyword BEGIN not expected. Valid tokens: THEN.
这通过了语法检查,注意 THEN
和 END IF
而不是 BEGIN
,COMMIT
而不是 COMMIT TRANSACTION
CREATE OR REPLACE PROCEDURE procedure2 ()
LANGUAGE SQL
BEGIN
UPDATE BASPPRC01
SET PRCCLASS=IN_PRCCLASS,PRCTER=IN_PRCTER,MESSAGE=IN_MESSAGE
WHERE CAST(IN_LOC||IN_MCO||IN_SYMBOL||IN_POLICYNUM||IN_MODULE||IN_RISKLOC AS CHAR(21))
= CAST(LOCATION||MASTERCO||SYMBOL||POLICYNUM||MODULE||RISKLOC AS CHAR(21)) ;
IF @@ROWCOUNT = 0 THEN
INSERT INTO BASPPRC01
(LOCATION,MASTERCO,SYMBOL,POLICYNUM,MODULE,RISKLOC,PRCCLASS,PRCTER,MESSAGE)
VALUES
(IN_LOC
, IN_MCO
, IN_SYMBOL
, IN_POLICYNUM
, IN_MODULE
, IN_RISKLOC
, IN_PRCCLASS
, IN_PRCTER
, IN_MESSAGE ) ;
END IF;
COMMIT;
END;
我有以下内联 SQL 代码,运行ning 在 AS400 上。 IF 出乎意料,但我不明白为什么。我想要做的是构建一个存储过程来更新或插入 table 行。下面显示的代码是内联的,以确保我的逻辑是正确的。
我尝试了多种不同的方法,包括 IF EXISTS、CASE、SET @COUNT = SELECT COUNT(*)。我继续 运行 进入奇怪的错误。
在下面显示的代码中,我在点击 IF 语句时失败了。
CREATE OR REPLACE VARIABLE IN_LOC CHAR(02);
CREATE OR REPLACE VARIABLE IN_MCO CHAR(02);
CREATE OR REPLACE VARIABLE IN_SYMBOL CHAR(03);
CREATE OR REPLACE VARIABLE IN_POLICYNUM CHAR(07);
CREATE OR REPLACE VARIABLE IN_MODULE CHAR(02);
CREATE OR REPLACE VARIABLE IN_RISKLOC CHAR(05);
CREATE OR REPLACE VARIABLE IN_PRCCLASS VARCHAR(05);
CREATE OR REPLACE VARIABLE IN_PRCTER VARCHAR(03);
CREATE OR REPLACE VARIABLE IN_MESSAGE CHAR(02);
SET IN_LOC='00';
SET IN_MCO='01';
SET IN_SYMBOL='CPP';
SET IN_POLICYNUM='0003748';
SET IN_MODULE='00';
SET IN_RISKLOC='00003';
SET IN_PRCCLASS='09';
SET IN_PRCTER='1';
SET IN_MESSAGE='NOT FOUND FOR ODD PROGRAMMING';
UPDATE BASPPRC01
SET PRCCLASS=IN_PRCCLASS,PRCTER=IN_PRCTER,MESSAGE=IN_MESSAGE
WHERE CAST(IN_LOC||IN_MCO||IN_SYMBOL||IN_POLICYNUM||IN_MODULE||IN_RISKLOC AS CHAR(21))
= CAST(LOCATION||MASTERCO||SYMBOL||POLICYNUM||MODULE||RISKLOC AS CHAR(21)) ;
IF @@ROWCOUNT = 0
BEGIN
INSERT INTO BASPPRC01
(LOCATION,MASTERCO,SYMBOL,POLICYNUM,MODULE,RISKLOC,PRCCLASS,PRCTER,MESSAGE)
VALUES
(IN_LOC
, IN_MCO
, IN_SYMBOL
, IN_POLICYNUM
, IN_MODULE
, IN_RISKLOC
, IN_PRCCLASS
, IN_PRCTER
, IN_MESSAGE ) ;
END
COMMIT TRANSACTION ;
你应该显示你得到的错误...
具有以下内容:
CREATE OR REPLACE PROCEDURE myproc ()
LANGUAGE SQL
BEGIN
UPDATE BASPPRC01
SET PRCCLASS=IN_PRCCLASS,PRCTER=IN_PRCTER,MESSAGE=IN_MESSAGE
WHERE CAST(IN_LOC||IN_MCO||IN_SYMBOL||IN_POLICYNUM||IN_MODULE||IN_RISKLOC AS CHAR(21))
= CAST(LOCATION||MASTERCO||SYMBOL||POLICYNUM||MODULE||RISKLOC AS CHAR(21)) ;
IF @@ROWCOUNT = 0
BEGIN
INSERT INTO BASPPRC01
(LOCATION,MASTERCO,SYMBOL,POLICYNUM,MODULE,RISKLOC,PRCCLASS,PRCTER,MESSAGE)
VALUES
(IN_LOC
, IN_MCO
, IN_SYMBOL
, IN_POLICYNUM
, IN_MODULE
, IN_RISKLOC
, IN_PRCCLASS
, IN_PRCTER
, IN_MESSAGE ) ;
END
COMMIT TRANSACTION ;
END;
我得到[SQL0199] Keyword BEGIN not expected. Valid tokens: THEN.
这通过了语法检查,注意 THEN
和 END IF
而不是 BEGIN
,COMMIT
而不是 COMMIT TRANSACTION
CREATE OR REPLACE PROCEDURE procedure2 ()
LANGUAGE SQL
BEGIN
UPDATE BASPPRC01
SET PRCCLASS=IN_PRCCLASS,PRCTER=IN_PRCTER,MESSAGE=IN_MESSAGE
WHERE CAST(IN_LOC||IN_MCO||IN_SYMBOL||IN_POLICYNUM||IN_MODULE||IN_RISKLOC AS CHAR(21))
= CAST(LOCATION||MASTERCO||SYMBOL||POLICYNUM||MODULE||RISKLOC AS CHAR(21)) ;
IF @@ROWCOUNT = 0 THEN
INSERT INTO BASPPRC01
(LOCATION,MASTERCO,SYMBOL,POLICYNUM,MODULE,RISKLOC,PRCCLASS,PRCTER,MESSAGE)
VALUES
(IN_LOC
, IN_MCO
, IN_SYMBOL
, IN_POLICYNUM
, IN_MODULE
, IN_RISKLOC
, IN_PRCCLASS
, IN_PRCTER
, IN_MESSAGE ) ;
END IF;
COMMIT;
END;