Uploaded image for project: 'Infinispan'
  1. Infinispan
  2. ISPN-12930

DB2TableManager looks into all schemas during table existence check

This issue belongs to an archived project. You can view it, but you can't modify it. Learn more

XMLWordPrintable

      This may border with a feature request.

      Scenario:

      When user configures a JDBC cache store, with IBM DB2 as a backing database, but doesn't specify a schema name, the DB2TableManager#tableExists(Connection connection, TableName tableName) call returns true even if the caching table is present in different schema.

      In effect the caching table in the current schema is not created and attempt to cache anything fails with SqlSyntaxErrorException: DB2 SQL Error: SQLCODE=-204, SQLSTATE=42704, SQLERRMC=dballo14.ispn_entry_cbnc_ear_a_war, DRIVER=4.25.23 error (i.e. table doesn't exist).

      For reproduction steps, see JBEAP-21362.

      The code that checks the existence of a table looks like this:

               DatabaseMetaData metaData = connection.getMetaData();
               String schemaPattern = tableName.getSchema(); // <- this is null
               rs = metaData.getTables(null, schemaPattern, tableName.getName(), new String[]{"TABLE"});
      

      Suggested improvement:

      If tableName.getSchema() returns null, the current schema name should be determined and supplied. On DB2 current schema can be obtained with SQL query "VALUES CURRENT SCHEMA".

              thofman Tomas Hofman
              thofman Tomas Hofman
              Archiver:
              rhn-support-adongare Amol Dongare

                Created:
                Updated:
                Resolved:
                Archived: