Q64934: An Alternative If ISAMCVT Fails on IBM BASIC 2.0 ISAM Database

Article: Q64934
Product(s): See article
Version(s): 7.00 7.10
Operating System(s): MS-DOS
Keyword(s): ENDUSER | SR# S900801-41 | mspl13_basic
Last Modified: 5-SEP-1990

ISAMCVT.EXE is a utility provided with Microsoft BASIC Professional
Development System (PDS) versions 7.00 and 7.10 for the purpose of
converting files created with other database-management systems,
including IBM BASIC Compiler version 2.00, to the Microsoft ISAM
format.

You can also convert the database using the REBUILD.EXE utility
provided in IBM BASIC Compiler version 2.00. IBM's REBUILD can be used
to strip the header information off the IBM ISAM data (.DAT) file. The
file can then be read in as a random access file and written out to a
Microsoft BASIC PDS 7.00 or 7.10 ISAM database.

This information applies to Microsoft BASIC Professional Development
System (PDS) versions 7.00 and 7.10 for MS-DOS.

For more information on the ISAMCVT.EXE utility, see Pages 391-393 of
the "Microsoft BASIC 7.0: Programmer's Guide" for versions 7.00 and
7.10.

This article contains the sample program CONVERT.BAS, which reads,
with random access, the file created by the REBUILD utility with the
/S option and writes the information out to a Microsoft BASIC PDS 7.00
or 7.10 ISAM database. Please note that this process does not save
indexes, so they will have to be rebuilt.

When an IBM BASIC 2.00 ISAM file is created, two files are actually
created: an index file with a .KEY extension, and a data file with the
.DAT extension. The .DAT file has a structure very similar to a random
access file except for the additional header information, known as the
"data dictionary." The data dictionary can be removed by using the
REBUILD utility with the /S option. The syntax is as follows:

   REBUILD SOURCE.DAT, TARGET.DAT /S;

The "Single-key" switch (/S) tells REBUILD to copy the source file
(the BASIC 2.00 data file) into the target file, removing the data
dictionary and any free space. No key file is built. The format of the
target file is a random access file with an additional 3-byte field
added to the beginning of each record. When reading the random file
into a BASIC 7.00 or 7.10 program, the TYPE...END TYPE statement must
be formatted the same way as the corresponding FIELD statement used in
the IBM BASIC 2.00 program, with the additional 3-byte field at the
beginning of each record. For example:

Used in BASIC 2.00 Program       Corresponding BASIC 7.00, 7.10 Declaration
--------------------------       ------------------------------------------

    FIELD #1, _                    TYPE BASIC20Rec
     25 as Name$, _                      Basic2Index AS STRING * 3
     30 as Address$, _                   Name AS STRING * 25
     4 as Zip$, _                        Address AS STRING * 30
     1 as Sex$, _                        Zip AS STRING * 4
     2 as Age$, _                        Sex AS STRING * 1
     4 as Income$                        Age AS STRING * 2
                                         Income AS STRING * 4
                                   END TYPE

Now you need to set up a TYPE...END TYPE statement to write the
appropriate information to an ISAM database or to another random
access file. This is to mask the BASIC 2.00 index off from the record.
You will have to dimension a variable or array of each type and assign
each of the individual fields, ignoring the 3-byte Basic2Index field.
For example:

     TYPE BASIC70Rec
           Name AS STRING * 25
           Address AS STRING * 30
           Zip AS DOUBLE        '7.00/7.10 ISAM doesn't support SINGLE
           Sex AS STRING * 1
           Age AS INTEGER
           Income AS DOUBLE     '7.00/7.10 ISAM doesn't support SINGLE
     END TYPE

     DIM OldRec AS BASIC20Rec
     DIM NewRec AS BASIC70Rec
               .
               .
               .
     NewRec.Name = OldRec.Name
     NewRec.Address = OldRec.Address
     NewRec.Zip = CVS(OldRec.Zip)
     NewRec.Sex = OldRec.Sex
     NewRec.Age = CVI(OldRec.Age)
     NewRec.Income = CVS(OldRec.Income)

Note that if floating-point values in records were written to the
file, you will need to convert them by invoking the QBX environment
with the /MBF option. This is because IBM BASIC Compiler 2.00 uses the
Microsoft Binary Format (MBF) for floating-point numbers, and
Microsoft BASIC PDS 7.00 and 7.10 use the IEEE format. For example:

   QBX /MBF

For more information on the ISAM utilities, query in this Knowledge
Base on the following words:

   ISAM and BASIC and UTILITY

Code Example
------------

'Below is CONVERT.BAS, the sample program that converts the sample ISAM
'file "MAIL.DAT" found on the IBM BASIC Compiler 2.00 disks. MAIL.DAT
'is rebuilt to the file "MAIL2.DAT" when the following command is typed
'at the DOS prompt:
'
'   REBUILD MAIL.DAT, MAIL2.DAT /S;
'
'The file is then read as a random file and each record is inserted
'into the database "CUSTOMER.MDB". For this example, invoke QBX.EXE
'with the /MBF option and load the PROISAMD.EXE TSR program.

DEFINT A-Z

'  Record description of data file MAIL2.DAT after REBUILD utility is
'  used:

TYPE BASIC2Rec
     Basic2Index AS STRING * 3  'This is the 3-byte index from REBUILD
     Name AS STRING * 25        'First and last name
     Address AS STRING * 30     'Address
     Zip AS STRING * 4          'Zip, SINGLE written to file using
                                'MKS$
     Sex AS STRING * 1          'Sex
     Age AS STRING * 2          'Age, INTEGER written to file using
                                'MKI$
     Income AS STRING * 4       'Income, SINGLE written to file using
                                'MKS$
END TYPE

TYPE BASIC7Rec
      Name AS STRING * 25      'First and last name
      Address AS STRING * 30   'Address
      Zip AS DOUBLE            'Zip, note the conversion process below
      Sex AS STRING * 1        'Sex
      Age AS INTEGER           'Age, note the conversion process below
      Income AS DOUBLE         'Income, note the conversion process
                               'below
END TYPE

DIM OldCust AS BASIC2Rec
DIM NewCust AS BASIC7Rec

OPEN "MAIL2.DAT" FOR RANDOM AS #1 LEN = LEN(OldCust)
OPEN "CUSTOMER.MDB" FOR ISAM BASIC7Rec "TABLE1" AS #2
CLS
i = 0
DO WHILE NOT EOF(1)
 i = i + 1
 GET #1, i, OldCust           'Get the old record

     'Assign the corresponding fields, ignoring the 3-byte index:

 NewCust.Name = OldCust.Name
 NewCust.Address = OldCust.Address
 NewCust.Zip = CVS(OldCust.Zip)        'Convert MBF to SINGLE
                                       'and assign into DOUBLE
 NewCust.Sex = OldCust.Sex
 NewCust.Age = CVI(OldCust.Age)        'Convert MBF to INTEGER
 NewCust.Income = CVS(OldCust.Income)  'Convert MBF to SINGLE
                                       'and assign to DOUBLE

     'Insert the array element into the ISAM database:

 INSERT #2, NewCust

LOOP

PRINT "The file is loaded into the database"   'tell user that the
                                               'file is loaded
PRINT "Number of records read: "; i; "  hit key to continue"
SLEEP

SETINDEX #2
MOVEFIRST #2                'Print out the database, to verify that
DO WHILE NOT EOF(2)         'the information is there.
      RETRIEVE #2, NewCust

      PRINT
      PRINT NewCust.Name
      PRINT NewCust.Address
      PRINT NewCust.Zip
      PRINT NewCust.Sex
      PRINT NewCust.Age
      PRINT NewCust.Income
      MOVENEXT #2
LOOP