Differences

This shows you the differences between the selected revision and the current version of the page.

wiki:sysmaster 2010/04/20 14:22 wiki:sysmaster 2014/04/30 20:59 current
Line 5: Line 5:
The window into the entire system, an area of shared memory with an SQL like interface The window into the entire system, an area of shared memory with an SQL like interface
 +
 +=====  How to drop sysmaster =====
 +
 +
 +  dbaccess sysmaster -
 + 
 +  delete from systables where tabid > 99 and partnum < '0x100000'; 
 + 
 +  delete from systables where tabname = 'sysdbspartn';
 + 
 +  close database;
 + 
 +  drop database sysmaster;
=====  How long has the user been connected ===== =====  How long has the user been connected =====
Line 75: Line 88:
            and syschunks.dbsnum = sysdbspaces.dbsnum             and syschunks.dbsnum = sysdbspaces.dbsnum
                       
 +
 +
Line 82: Line 97:
            where tabid = 99             where tabid = 99
                       
 +
 +Works fine on the earlier engines, not so good on the later ones as the Official Release doesn't tally back  i.e. 10.00.FC6 reports 9.50C1, and 11.50.FC6 reports 9.53C1 etc. However,
 +
 +  DBINFO('version','server-type')
 +  DBINFO('version','major')
 +  DBINFO('version','minor')
 +  DBINFO('version','os')
 +  DBINFO('version','full')
 +
 +All should work
 +
=====  How to list the users ===== =====  How to list the users =====
Line 273: Line 299:
            group by 1             group by 1
                       
 +
Line 294: Line 321:
            or sqx_executions > 1)             or sqx_executions > 1)
            and sqx_bufreads / sqx_executions > 50000             and sqx_bufreads / sqx_executions > 50000
 +
 +The following SQL identifies the unused indexes
 +
 +  SELECT
 +    x1.dbsname,
 +    x3.tabname,
 +    x1.tabname AS idxname,
 +    (x4.npused * x4.pagesize / 1024) :: INT AS size_kb
 +  FROM
 +    systabnames AS x1, sysptntab AS x2,
 +    systabnames AS x3, sysptnhdr AS x4
 +  WHERE x2.partnum = x1.partnum
 +    AND x2.partnum != x2.tablock
 +    AND x3.partnum = x2.tablock
 +    AND x4.partnum = x1.partnum
 +    AND x1.dbsname MATCHES '[a-z]*'
 +    AND x3.tabname MATCHES '[a-z]*'
 +    AND x2.pf_isread = 0
 +    AND x2.pf_iswrite > 0
 +  ORDER BY 4 DESC
 +
In the later engines, or databases with detached indices this information is also available via Table IO stats but the indexname as the table filter In the later engines, or databases with detached indices this information is also available via Table IO stats but the indexname as the table filter
Line 748: Line 796:
  3 SD secondary server   3 SD secondary server
  4 RS secondary server   4 RS secondary server
 +
Line 769: Line 818:
    where b.dbsnum = trunc(a.partnum/1048576)     where b.dbsnum = trunc(a.partnum/1048576)
      and c.idxname = a.tabname       and c.idxname = a.tabname
 +      and a.dbsname = '<database>'
      and tabid > 99       and tabid > 99
  order by 1   order by 1
 +
 +===== What are the unused indexes =====
 +
 +  select sysindexes.idxname index, sysindexes.idxtype as type, sysptprof.isreads reads
 +    from sysindexes, sysmaster:sysptprof sysptprof
 +    where sysindexes.idxname = sysptprof.tabname
 +      and sysptprof.isreads = 0
 +    order by reads desc, idxname ;

Personal Tools