Archive-name: databases/sybase-faq/part16
URL: http://www.isug.com/Sybase_FAQ
Version: 1.7
Maintainer: David Owen
Last-modified: 2003/01/17
Posting-Frequency: posted every 3rd month
   A how-to-find-the-FAQ article is posted on the intervening months.
                                   Freeware                                    
                                                                               
 
Sybase Tech Docs Open Client ASE FAQ
 
The best place to search for Sybase freeware is Ed Barlow ([email protected])'s
site (http://www.edbarlow.com).   He is likely to spend more time maintaining
his list than I will spend on this.   I will do my best!
    9.0      Where is all the code and why does Section 9 suddenly load in a
    reasonable amount of time?
   
    Stored Procedures
   
    9.1.1      sp_freedevice - lists device, size, used and free.
    9.1.2      sp_dos - This procedure graphically displays the scope of a
    object
    9.1.3      sp_whodo - augments sp_who by including additional columns: cpu,
    I/O...
    9.1.4      sp__revroles - creates DDL to sp_role a mirror of your SQL
    Server
    9.1.5      sp__rev_configure - creates DDL to sp_configure a mirror of your
    SQL Server
    9.1.6      sp_servermap - overview of your SQL Server
    9.1.7      sp__create_crosstab - simplify crosstable queries
    9.1.8      sp_ddl_create_table - creates DDL for all user tables in the
    current database
    9.1.9      sp_spaceused_table
    9.1.10    SQL to determine the space used for an index.
    9.1.11    sp_helpoptions - Shows what options are set for a database.
    9.1.12    sp_days - returns days in current month.
    9.1.13    sp__optdiag - optdiag from within isql
    9.1.14    sp_desc - a simple list of a tables' columns
    9.1.15    sp_lockconfig - Displays locking schemes for tables.
   
    Shell Scripts
   
    9.2.1      SQL and sh(1)to dynamically generate a dump/load database
    command.
    9.2.2      update statistics script
   
    Perl/Sybperl
   
    9.3.1      SybPerl - Perl interface to Sybase.
    9.3.2      dbschema.pl - Sybperl script to reverse engineer a database.
    9.3.3      ddl_insert.pl - creates insert DDL for a table.
    9.3.4      int.pl - converts interfaces file to tli
    9.3.5      Sybase::Xfer.pm - Module to transfer data between two servers.
    9.3.6      sybmon.pl - realtime process and lock monitor
    9.3.7      showserver.pl - shows the servers on a particular machine in a
    nice format.
    9.3.8      Collection of Perl Scripts
   
    Sybtcl
   
    9.4.1      Sybtcl - TCL interface to Sybase.
    9.4.2      sybdump - a Tcl script for dumping a database schema to disk
    9.4.3      wisql - graphical sql editor and more
   
    Python
   
    9.5.1      Sybase Module for Python.
   
    Tools, Utilities and Packages
   
    9.6.1      sqsh - a superset of dsql with local variables, redirection,
    pipes and all sorts of goodies.
    9.6.2      lightweight Sybase Access via Win95/NT
    9.6.3      BCPTool - a utility for trasferring data from ASE to another
    (inc. native port to Linux).
   
    'Free' Versions of ASE
   
    The next couple of questions will move to the OS section (real) soon.
   
    9.7.1      How to access a SQL Server using Linux see also Q11.4.6
    9.7.2      Sybase on Linux Linux Penguin
    9.7.3      How to configure shared-memory for Linux
    9.7.4      Sybase now available on Free BSD
   
    Other Sites of Interest
   
    9.8.1      Ed Barlow's collection of Stored Procedures.
   
    9.8.2      Examples of Open Client and Open Server programs -- see Q11.4.14
    .
    9.8.3      xsybmon - an X interface to sp_monitor
Sybase Tech Docs Open Client ASE FAQ
-------------------------------------------------------------------------------
9.0: Where is all the code and why does Section 9 suddenly load in a reasonable
amount of time?
-------------------------------------------------------------------------------
This section was in need of a spring clean, and it has now had it. I have
tested all of the stored procs included here against all versions of Sybase
that I have to hand. (11.0.3.3, 11.9.2 and 12.5 on Linux, 11.9.2 and 12 on
Solaris and 11.9.2 and 12 on NT.) If Pablo or the supplier documented that he
had tested it on other versions, then I have included those comments. Just
remember that I did not test them on anything pre-11.0.3.3. If you are still
using them on a pre-11.0.3.3 release (I know of at least one place that is
still running 4.9.2!) then let me know and I will add a suitable comment.
I have actually taken the code away and built a set of packages. First and
foremost is the stored proc package, then there is a shell script package, a
perl package and finally there is the archive package, which contains any stuff
specific to non-current releases of ASE.
In addition to wrenching out the code I have added some samples of the output
generated by the scripts. It occurred to me that people will be better able to
see if the stored proc does what they want if they can see what it produces.
Finally, part of the reason that this is here is so that people can examine the
code and see how other people write stored procs etc. Each stored proc is in a
file of its own so that you can choose which ones you wish to browse on-line
and then cut and paste them without having to go through the hassle of
un-htmling them.
Back to top
9.1.1: sp_freedevice
-------------------------------------------------------------------------------
This script displays the size of the devices configured for a server, together
with the free and used allocations.
Get it as part of the bundle (zip or tarball) or individually from here.
Output:
1> sp_freedevice
2> go
 total used free
 ------------- ------------- -------------
 450.0 MB      376.0 MB      74.0 MB
(1 row affected)
 devname                        size          used          free
 ------------------------------ ------------- ------------- -------------
 db01                           50.0 MB       50.0 MB       0.0 MB
 db02                           50.0 MB       50.0 MB       0.0 MB
 lg01                           25.0 MB       25.0 MB       0.0 MB
 lg02                           25.0 MB       25.0 MB       0.0 MB
 master                         100.0 MB      26.0 MB       74.0 MB
 sysprocsdev                    150.0 MB      150.0 MB      0.0 MB
 tmp01                          50.0 MB       50.0 MB       0.0 MB
(7 rows affected)
(return status = 0)
Back to top
-------------------------------------------------------------------------------
9.1.2: sp_dos
-------------------------------------------------------------------------------
sp_dos displays the scope of an object within a database. What tables it
references, what other procedures it calls etc. Very useful for trying to
understand an application that you have just inherited.
Get it as part of the bundle (zip or tarball) or individually from here.
The output looks like this:
1> sp_dos sp_helpkey
2> go
** Utility by David Pledger, Strategic Data Systems, Inc.  **
**         PO Box 498, Springboro, OH  45066               **
         SCOPE OF EFFECT FOR OBJECT:  sp_helpkey
+------------------------------------------------------------------+
(P) sp_helpkey
|
+--(S) sysobjects
|
+--(S) syskeys
|
+--(P) sp_getmessage
   |
   +--(S) sysusermessages
   |
   +--(P) sp_validlang
(return status = 0)
1>
Back to top
-------------------------------------------------------------------------------
9.1.3: sp_whodo
-------------------------------------------------------------------------------
Sybase System 10.x and above
sp_whodo is an enhanced version of sp_who, with cpu and io usage for each user.
Note that this proc is now a little out of date since Sybase introduced the fid
column, so subordinate threads are unlikely to be grouped with their parent.
Get it as part of the bundle (zip or tarball) or individually from here.
Output:
1> sp_whodo
2> go
 spid   status       loginame     hostname   blk blk_sec program
         dbname  cmd              cpu    io      tran_name
 ------ ------------ ------------ ---------- --- ------- ----------------
        ------- ---------------- ------ ------- ----------------
      2 sleeping     NULL                    0   0
         master  NETWORK HANDLER  0      0
      4 sleeping     NULL                    0   0
         master  DEADLOCK TUNE    0      0
      5 sleeping     NULL                    0   0
         master  MIRROR HANDLER   0      0
      6 sleeping     NULL                    0   0       <astc>
         master  ASTC HANDLER     0      0
      7 sleeping     NULL                    0   0
         master  CHECKPOINT SLEEP 0      128
      8 sleeping     NULL                    0   0
         master  HOUSEKEEPER      0      33
     17 running      sa           n-utsire.m 0   0       ctisql
         master  SELECT           0      1
(7 rows affected)
Back to top
-------------------------------------------------------------------------------
9.1.4: sp__revroles
-------------------------------------------------------------------------------
Well, I cannot get this one to do what it is supposed to, I am not sure if it
is just that it was written for a different release of Sybase and 11.9.2 and
above has changed the way that roles are built, or what. Anyway, I may work on
it some more.
Get it as part of the bundle (zip or tarball) or individually from here.
Back to top
-------------------------------------------------------------------------------
9.1.5: sp__rev_configure
-------------------------------------------------------------------------------
This proc reverse engineers the configure settings. It produces a set of calls
to sp_configure for those values that appear in syscurconfigs. I am not sure
how relevant this is with the ability to save and load the config file.
Get it as part of the bundle (zip or tarball) or individually from here.
The output is as follows, however, I have edited away some of the values since
my list was considerably longer than this.
 -- sp_configure settings
 -------------------------------------------------------------
 sp_configure 'recovery interval', 5
go
 sp_configure 'allow updates', 0
go
 sp_configure 'user connections', 25
go
 sp_configure 'memory', 14336
go
 sp_configure 'default character set id', 2
go
 sp_configure 'stack size', 65536
go
 sp_configure 'password expiration interval', 0
go
 sp_configure 'audit queue size', 100
go
 sp_configure 'additional netmem', 0
go
 sp_configure 'default network packet size', 512
go
 sp_configure 'maximum network packet size', 512
go
 sp_configure 'extent i/o buffers',
go
 sp_configure 'identity burning set factor', 5000
go
 sp_configure 'size of auto identity', 10
go
 sp_configure 'identity grab size', 1
go
 sp_configure 'lock promotion threshold', 200
go
(41 rows affected)
(return status = 0)
Back to top
-------------------------------------------------------------------------------
9.1.6: sp_servermap
-------------------------------------------------------------------------------
A one stop shop for a quick peek at everything on the server.
Get it as part of the bundle (zip or tarball) or individually from here.
The output for a brand new 11.0.3.3 ASE on Linux server is as follows:
                                Current Date/Time
 ------------------------------ --------------------------
 TRAFALGAR                             Jan 14 2001  1:48PM
 Version
 -------------------------------------------------------------------------------------------------
 SQL Server/11.0.3.3 ESD#6/P-FREE/Linux Intel/Linux 2.2.14 i686/1/OPT/Fri Mar 17 15:45:30 CET 2000
A - DATABASE SEGMENT MAP
************************
 db              dbid   segmap      segs device fragment start (pg)  size (MB)
 --------------- ------ ----------- ---- --------------- ----------- ---------
 master               1           7  LDS master                    4    3.00
 master               1           7  LDS master                 3588    2.00
 tempdb               2           7  LDS master                 2564    2.00
 model                3           7  LDS master                 1540    2.00
 sybsystemprocs       4           7  LDS sysprocsdev        16777216  150.00
 sybsecurity          5          15 ULDS sybsecurity        33554432  300.00
Segment Codes:
U=User-defined segment on this device fragment
L=Database Log may be placed on this device fragment
D=Database objects may be placed on this device fragment by DEFAULT
S=SYSTEM objects may be placed on this device fragment
B - DATABASE INFORMATION
************************
 db              dbid   size (MB) db status codes    created
         dump tran
 --------------- ------ --------- ------------------ ---------------
        ---------------
 master               1    5.00                      01 Jan 00 00:00
         07 Jan 01 04:01
 tempdb               2    2.00   A                  14 Jan 01 13:46
         14 Jan 01 13:47
 model                3    2.00                      01 Jan 00 00:00
         07 Jan 01 03:38
 sybsystemprocs       4  150.00    B                 07 Jan 01 03:32
         14 Jan 01 13:43
 sybsecurity          5  300.00    B                 07 Jan 01 04:01
         07 Jan 01 04:55
Status Code Key
Code       Status
----       ----------------------------------
 A         select into/bulk copy allowed
 B         truncate log on checkpoint
 C         no checkpoint on recovery
 D         db in load-from-dump mode
 E         db is suspect
 F         ddl in tran
 G         db is read-only
 H         db is for dbo use only
 I         db in single-user mode
 J         db name has been changed
 K         db is in recovery
 L         db has bypass recovery set
 M         abort tran on log full
 N         no free space accounting
 O         auto identity
 P         identity in nonunique index
 Q         db is offline
 R         db is offline until recovery completes
C - DEVICE ALLOCATION MAP
*************************
 device fragment start (pg)  size (MB) db              lstart      segs
 --------------- ----------- --------- --------------- ----------- ----
 master                    4    3.00   master                    0  LDS
 master                 1540    2.00   model                     0  LDS
 master                 2564    2.00   tempdb                    0  LDS
 master                 3588    2.00   master                 1536  LDS
 sybsecurity        33554432  300.00   sybsecurity               0 ULDS
 sysprocsdev        16777216  150.00   sybsystemprocs            0  LDS
Segment Codes:
U=USER-definedsegment on this device fragment
L=Database LOG may be placed on this device fragment
D=Database objects may be placed on this device fragment by DEFAULT
S=SYSTEM objects may be placed on this device fragment
D - DEVICE NUMBER, DEFAULT & SPACE USAGE
****************************************
 device          vdevno default disk? total (MB) used    free
 --------------- ------ ------------- ---------- ------- -------
 master               0     Y          100.00       9.00   91.00
 sysprocsdev          1     N          150.00     150.00    0.00
 sybsecurity          2     N          300.00     300.00    0.00
E - DEVICE LOCATION
*******************
 device          location
 --------------- ------------------------------------------------------------
 master          d_master
 sybsecurity     /d/TRAFALGAR/3/sybsecur.dat
 sysprocsdev     /d/TRAFALGAR/2/sybprocs.dat
NO DEVICES ARE MIRRORED
(return status = 0)
Back to top
-------------------------------------------------------------------------------
9.1.7: sp__create_crosstab
-------------------------------------------------------------------------------
Hmmm... not quite sure about this one. Was not 100% sure about how to set it
up. From the description it builds a cross tab query. If someone knows how to
use this, then let me know how to set it up and I will improve the description
here and provide some output.
Get it as part of the bundle (zip or tarball) or individually from here.
Back to top
-------------------------------------------------------------------------------
9.1.8: sp_ddl_create_table
-------------------------------------------------------------------------------
Well, you all know what a create table statement looks like... This produces
the table definitions in their barest form (lacking in constraints etc) and the
resulting DDL is perhaps not as elegant as some other utilities, but far be it
from me to blow dbschema's trumpet :-), but it is worth a look just for the
query. The layout of the carriage returns being embedded within strings is
deliberate!
Get it as part of the bundle (zip or tarball) or individually from here.
Back to top
-------------------------------------------------------------------------------
9.1.9: sp_spaceused_table
-------------------------------------------------------------------------------
Brief
In environment where there are a lot of temporary tables #x being created, how
do you tell who is using how much space ? The answer is sp_spaceused_table,
which basically lists the tables in a database with rowcount and space usage
statistics. I have replaced the original proc with K-shell script for a single
proc. I think that it is easier to compare if it is all in one listing.
However, if you disagree I will add the original code to the archive package,
just let me know.
Get it as part of the bundle (zip or tarball) or individually from here.
The output of the proc is as follows: (I used sqsh, hence the prompt, since it
auto-resizes its width as you resize the xterm.)
[25] N_UTSIRE.tempdb.1> sp_spaceused_table
[25] N_UTSIRE.tempdb.2> go
 name                                          rowtotal    reserved        data            index_size      unused
 --------------------------------------------- ----------- --------------- --------------- --------------- ---------------
 #matter______00000010014294376                12039       3920 KB         3910 KB         0 KB            10 KB
 #synopsis____00000010014294376                6572        15766 KB        274 KB          15472 KB        20 KB
 #hearing_____00000010014294376                5856        572 KB          568 KB          0 KB            4 KB
 #hearing2____00000010014294376                5856        574 KB          568 KB          0 KB            6 KB
 #hearing3____00000010014294376                5856        574 KB          568 KB          0 KB            6 KB
 #synopsis2___00000010014294376                6572        15820 KB        274 KB          15472 KB        74 KB
(return status = 0)
Back to top
-------------------------------------------------------------------------------
-- 
- David Alex Lamb, one of the *.answers moderators
[email protected]
| Закладки на сайте Проследить за страницей | Created 1996-2025 by Maxim Chirkov Добавить, Поддержать, Вебмастеру |