How to resolve SQL0418N Error

前端 未结 1 1514
轮回少年
轮回少年 2020-11-30 14:59

I\'m using the statement below to update/insert some data to a table and, if I run it without parameters, it\'s fine. However, as soon as I try to execute it using parameter

相关标签:
1条回答
  • 2020-11-30 15:39

    Basically, DB2 doesn't know what data types you're sending in on those parameters. I'm guessing you're either on an older version of DB2 (less than 9.7 on Linux/Unix/Windows, or on a Mainframe version older than 10.1), which doesn't do a whole lot of "automatic" type conversion. Or you're sending in NULL values (which still have to be "typed", strange as it sounds).

    You can fix the problem by creating your parameter markers as typed parameters (I'm assuming data types here, use what would be appropriate):

    MERGE INTO AB.TESTING_TABLE A
    USING (VALUES (
              CAST(@TEST AS CHAR(4))
             ,CAST(@ACTION AS CHAR(1))
           )) B(TEST_ID, "ACTION")
       ON (A.TEST_ID = B.TEST_ID)
     WHEN NOT MATCHED THEN
         INSERT (TEST_ID, "ACTION")
         VALUES (B.TEST_ID, B.ACTION)
    WHEN MATCHED THEN
         UPDATE SET "ACTION" = B.ACTION
    

    Additionally, since you're using the MERGE, you don't have to use parameters in the UPDATE or INSERT parts, you can refer to the values in the USING table you passed in. Also, since you're matching on TEST_ID, you don't need to include that in your UPDATE statement, since it wouldn't be updated, anyway.

    0 讨论(0)
提交回复
热议问题