home *** CD-ROM | disk | FTP | other *** search
/ Chip 1999 January / Chip_1999-01_cd.bin / zkuste / delphi / info / PACK.TXT < prev    next >
Text File  |  1998-10-12  |  4KB  |  71 lines

  1. Packing a Paradox or dBase Table
  2. How do I pack a Paradox (or dBase) table to optimize its indexes and space used?
  3.  
  4. Wouldn't it be great for the TTable component to have a method that does this? Just open up a TTable, connected it to a table on disk, call the method, and wham! The table's packed (Hmm.... I just might have to look into that). But short of that, you have to make direct calls to the BDE to accomplish this task. For dBase tables, it's easy. There's a single function called dbiPackTable that'll pack any dBase file. For Paradox files, you have to jump through a couple of hoops first, then call dbiDoRestructure because Paradox tables can only be packed within the context of a table restructure (Note: If you've restructured a table in Paradox or the Database Desktop, you'll notice a checkbox at the bottom of the restructure dialog called "Pack Table").
  5.  
  6. Below is a simple procedure for packing tables. I took most of the code right out of the online help (yes, there's really good stuff in there if you know where look), and made some alterations. The difference between what I did and what the help file lists is that instead of the formal parameter being a TTable, I require a fully qualified file name (path/name). This allows for greater flexibility - the procedure opens up its own TTable and works on it instead you having to create one yourself. I guess it might all boil down to semantics, but I still like my way better (so there!). Check out the code below:
  7.  
  8. procedure PackTable(TblName : String);
  9. var
  10.   tbl     : TTable;
  11.   cProps  : CURProps;
  12.   hDb     : hDBIDb;
  13.   TblDesc : CRTblDesc;
  14. begin
  15.  
  16.   tbl := TTable.Create(nil);
  17.   with tbl do begin
  18.     Active := False;
  19.     DatabaseName := ExtractFilePath(TblName);
  20.     TableName := ExtractFileName(TblName);
  21.     Open;
  22.     Exclusive := True;
  23.   end;
  24.  
  25.   // Make sure the table is open exclusively so we can get the db handle...
  26.   if not tbl.Active then
  27.     raise EDatabaseError.Create('Table must be opened to pack');
  28.  
  29.   if not tbl.Exclusive then
  30.     raise EDatabaseError.Create('Table must be opened exclusively to pack');
  31.  
  32.   // Get the table properties to determine table type...
  33.   Check(DbiGetCursorProps(tbl.Handle, cProps));
  34.  
  35.   // If the table is a Paradox table, you must call DbiDoRestructure...
  36.   if (cProps.szTableType = szPARADOX) then
  37.     begin
  38.       // Blank out the structure...
  39.       FillChar(TblDesc, sizeof(TblDesc), 0);
  40.       // Get the database handle from the table's cursor handle...
  41.       Check(DbiGetObjFromObj(hDBIObj(tbl.Handle), objDATABASE, hDBIObj(hDb)));
  42.       // Put the table name in the table descriptor...
  43.       StrPCopy(TblDesc.szTblName, tbl.TableName);
  44.       // Put the table type in the table descriptor...
  45.       StrPCopy(TblDesc.szTblType, cProps.szTableType);
  46.       // Set the Pack option in the table descriptor to TRUE...
  47.       TblDesc.bPack := True;
  48.       // Close the table so the restructure can complete...
  49.       tbl.Close;
  50.       // Call DbiDoRestructure...
  51.       Check(DbiDoRestructure(hDb, 1, @TblDesc, nil, nil, nil, False));
  52.     end
  53.   else
  54.     // If the table is a dBASE table, simply call DbiPackTable...
  55.     if (cProps.szTableType = szDBASE) then
  56.       Check(DbiPackTable(tbl.DBHandle, tbl.Handle, nil, szDBASE, True))
  57.     else
  58.       // Pack only works on PAradox or dBASE; nothing else...
  59.       raise EDatabaseError.Create('You can only pack Paradox or dBase tables!');
  60.  
  61.   with tbl do begin
  62.     if Active then
  63.       Close;
  64.     Free;
  65.   end;
  66. end;
  67. See? Nothing fancy. What you should know is that all operations involving dbiDoRestructure revolve around a table descriptor type CRTblDesc. With this record type, you can set various field values, then execute dbiDoRestructure to make your changes. That's kind of the trick to making BDE calls in general. You typically work with some sort of record structure, then use that structure in one of the calls. I know I'm probably oversimplifying, but that's it in a nutshell. The point? Don't be scared of the BDE. More later!
  68.  
  69. I encourage you to look at the BDE online help under any dbi- subject. There are lots of code examples that will get you on your way.
  70.  
  71.