Uploaded image for project: 'Derby'
  1. Derby
  2. DERBY-3788

Provide a zero-admin way of updating the statisitcs of an index

    Details

    • Type: Improvement
    • Status: Closed
    • Priority: Major
    • Resolution: Duplicate
    • Affects Version/s: 10.5.1.1
    • Fix Version/s: 10.8.1.2
    • Component/s: Store
    • Labels:
      None
    • Bug behavior facts:
      Performance

      Description

      DERBY-269 provided a manual way of updating the statistics using the new system stored procedure SYSCS_UTIL.SYSCS_UPDATE_STATISTICS. It will be good for Derby to provide an automatic way of updating the statistics without requiring to run the stored procedure manually. There was some discussion on DERBY-269 about providing the 0-admin way. I have copied it here for reference.

      *********************
      Kathey Marsden - 22/May/05 03:53 PM
      Some sort of zero admin solution for updating statistics would be prefferable to the manual 'update statistics'
      *********************

      *********************
      Mike Matrigali - 11/Jun/08 12:37 PM
      I have not seen any other suggestions, how about the following zero admin solution? It is not perfect - suggestions welcome.

      Along with the statistics storing, save how many rows were in the table when exact statistics were calculated. This number is 0 if none have been calculated because index creation happened on an empty table. At query compile time when we look up statistics we automatically recalculate the statistics at certain threshholds - say something like row count growing past next threshhold : 10, 100, 1000, 100000 - with upper limit being somewhere around how many rows we can process in some small amount of time - like 1 second on a modern laptop. If we are worried about response time, maybe we background queue the stat gathering rather than waiting with maybe some quick load if no stat has ever been gathered. The background gathering could be optimized to not interfere with locks by using read uncommitted.

      I think it would be useful to also have the manual call just to make it easy to support customers and debug issues in the field. There is proably always some dynamic data distribution change that in some case won't be picked up by the automatic algorithm. Also just very useful for those who have complete control of the create ddl, load data, run stats, deliver application process.
      *********************

        Attachments

        1. DERBY_3788_Mgr.java
          0.8 kB
          Mamta A. Satoor
        2. DERBY_3788_Repro.java
          0.3 kB
          Mamta A. Satoor
        3. DERBY3788_patch1_diff.txt
          14 kB
          Mamta A. Satoor
        4. DERBY3788_patch1_stat.txt
          1.0 kB
          Mamta A. Satoor
        5. DERBY3788_patch2_diff.txt
          19 kB
          Mamta A. Satoor
        6. DERBY3788_patch2_stat.txt
          1 kB
          Mamta A. Satoor
        7. DERBY3788_patch3_diff.txt
          17 kB
          Mamta A. Satoor
        8. DERBY3788_patch3_stat.txt
          1 kB
          Mamta A. Satoor
        9. DERBY3788_update_all_missing_stats_after_bind_patch4_stat.txt
          0.5 kB
          Mamta A. Satoor
        10. DERBY3788_update_all_missing_stats_after_bind_patch4_diff.txt
          20 kB
          Mamta A. Satoor

          Issue Links

            Activity

              People

              • Assignee:
                mamtas Mamta A. Satoor
                Reporter:
                mamtas Mamta A. Satoor
              • Votes:
                0 Vote for this issue
                Watchers:
                3 Start watching this issue

                Dates

                • Created:
                  Updated:
                  Resolved: