1. Derby
  2. DERBY-3173

Removed cached String objects from SQLDate, SQLTime and SQLTimestamp


    • Type: Improvement Improvement
    • Status: Closed
    • Priority: Minor Minor
    • Resolution: Fixed
    • Affects Version/s: None
    • Fix Version/s:
    • Component/s: SQL
    • Labels:
    • Issue & fix info:


      These type classes save a copy of the value when it is converted to a String (e.g. through a ResultSet.getString()). This complicates the code & increases memory use for little value, in most cases the cached value will never be used. E.g. for any type of scan the String value will be discarded when moving to the next row. In most cases applications do not call getString() twice on a column.

      The code has some historical basis in the fact that these types used to be represented by a java.sql.Time/Date/Timestamp object and its conversion to String was slow. Now the conversion of all these types to a String is simple.

      In addition I think the getString() will sometimes return a non-normalized form, if the value is set by a non-standard format then the cached String is set to the non-standard format, not the standard format, I believe this is incorrect.

      1. sqldate.diff
        2 kB
        Knut Anders Hatlen
      2. Derby-3173.diff
        2 kB
        Eranda Sooriyabandara
      3. Derby-3173.diff
        5 kB
        Eranda Sooriyabandara
      4. Derby-3173.diff
        6 kB
        Eranda Sooriyabandara
      5. d3173.diff
        7 kB
        Knut Anders Hatlen
      6. d3173_warning.diff
        0.6 kB
        Eranda Sooriyabandara


        No work has yet been logged on this issue.


          • Assignee:
            Eranda Sooriyabandara
            Daniel John Debrunner
          • Votes:
            0 Vote for this issue
            1 Start watching this issue


            • Created: