How to fix possible db corruption?

前端 未结 5 1767
花落未央
花落未央 2020-12-21 01:47

I\'m at a client doing some quick fixes to their access application. It was a while I had a go with access, but I\'m recovering quickly. However, I\'ve discovered an interes

相关标签:
5条回答
  • 2020-12-21 02:31

    Have you tried the built in Access compact/repair tool? This should flush deleted records from the database.

    The exact location varies according to the version of Access you're running, but on Access 2003 it's under Tools > Database Utilities > Compact and repair database. Some earlier versions of Access had two separate tools - one for compact, one for repair - but they were accessed from a similar location. If they are separate on the version the client has, you need to run both.

    This should be a non-destructive operation, but it would be best to test this on a copy of the MDB file (apologies for stating the obvious).

    0 讨论(0)
  • 2020-12-21 02:41

    Aside from the options already posted above, I've used another simple method aswell: Simply create a new MDB file and import all objects from the corrupted one. Don't forget to get system and/or hidden objects when you go this way.

    0 讨论(0)
  • 2020-12-21 02:42

    Tony Toews, Access MVP, has a comprehensive guide to corruption:

    Corrupt Microsoft Access MDBs FAQ

    • Some corruption symptoms
    • Determining the workstation which caused the corruption
    • Corruption causes
    • To retrieve your data

    As an aside, decompile is very useful for sorting out odd happenings when coding and for improving start-up times.

    0 讨论(0)
  • 2020-12-21 02:44

    Compacting and importing won't fix the problem for the error reported, which is clearly a corrupted pointer for a memo field. The only thing you can do is delete and recreate the record that is causing the problem. And you need to find ways to edit memo data (or eliminate memo fields -- do you really need more than 255 characters or not?) that does not expose you to corruption risk. That means avoiding bound controls on forms for memo fields.

    Instead, use an unbound textbox, and in the form's OnCurrent event, assign the current data from the form's underlying recordsource:

      Me!txtMyMemo = Me!MyMemo
    

    To save edits to the unbound control, use the control's AfterUpdate event:

      Me!MyMemo = Me!txtMyMemo
      Me.Dirty = False        ' save the whole record
    

    Why are memo fields subject to corruption? Because they aren't stored in the same data page as the non-memo fields, but instead, all that is in the record's main data page is a pointer to some other data page (or set of data pages if it's a large chunk of data) where the actual memo data is stored. If it weren't done this way, a record with a memo in it would very quickly exceed the maximum record length.

    The pointer is relatively easily corrupted, most often by a fatal problem during editing in a bound control. Editing with an unbound control does not eliminate the problem entirely, but means that the time in which you're exposed to danger is very, very short (i.e., the time it takes for those two lines of code to execute in the AfterUpdate event).

    0 讨论(0)
  • 2020-12-21 02:45

    you can also try this Command line utility

    //andy

    0 讨论(0)
提交回复
热议问题