日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

access下如何恢復(fù)已經(jīng)刪除的記錄;如何恢復(fù)已經(jīng)刪除的表、窗體等等對象

瀏覽:349日期:2023-03-18 16:41:52
問題:

    如何恢復(fù)已經(jīng)刪除的記錄;如何恢復(fù)已經(jīng)刪除的表、窗體等等對象
1、我用 DELETE FROM TABLE 刪除了一些記錄,現(xiàn)在發(fā)現(xiàn)誤刪除了,該如何恢復(fù)?
2、我直接手動刪除或者用 DROP TABLE 刪除了一個表,現(xiàn)在發(fā)現(xiàn)是誤刪除了,該如何恢復(fù)?
3、我手動刪除了一個窗體,該如何恢復(fù)?
4、我刪除了記錄,可是數(shù)據(jù)庫體積并沒有減小,那么是否能找回記錄呢?

 


回答:

    1、已經(jīng)刪除的記錄是無法恢復(fù)的,ACCESS 不是 FOXPRO,MDB 格式不是 DBF 格式,沒有邏輯刪除和物理刪除的概念,一旦刪除就無法恢復(fù)了。
2、無法恢復(fù),但是你可以查看一下,有沒有隱藏的以 "~" 符號開頭的表,更改該表的名稱有可能找回你需要的表。
3、無法恢復(fù),但是你可以查看一下有沒有系統(tǒng)隱藏的對象,有時候?qū)ο蟊粍h除時系統(tǒng)并不直接刪除,而是更改對象名后隱藏它。
4、數(shù)據(jù)庫體積的確沒有變小,你壓縮修復(fù)數(shù)據(jù)庫后體積就會變小了。那是因為在二進制上你的數(shù)據(jù)的確沒有被刪除,仍然存放在磁盤的某個扇區(qū),但是微軟沒有提供 MDB 格式二進制組織方式的參考資料(微軟也不會提供,其他第三方公司也沒有權(quán)利直接反編譯 MDB 格式)。至今為止,中國大陸我也沒有看到過相關(guān)的參考資料。所以目前為止,你已經(jīng)刪除的數(shù)據(jù)是無法恢復(fù)的。但是你可以嘗試使用磁盤恢復(fù)軟件來找到恢復(fù)數(shù)據(jù)的方法,但是該方法不在本文討論范圍。

建議:在建立數(shù)據(jù)庫結(jié)構(gòu)時,可以在各個表中再多加一個 ISDEL 字段,刪除記錄時不使用 DELETE FROM ,而使用 UPDATE TABLE SET ISDEL=TRUE 這樣的語句,然后在界面上不顯示 ISDEL=TRUE 的記錄即可。
復(fù)制代碼 代碼如下:
如果還沒有被壓縮理論上可以。試試這段代碼吧。加在access模組中
恢復(fù)刪除的工作表(未被壓縮)
 
Public Function FnUndeleteObjects() As Boolean
  On Error GoTo ErrorHandler:
  Dim strObjectName           As String
  Dim rsTables                As DAO.Recordset
  Dim dbsDatabase             As DAO.Database
  Dim tDef                    As DAO.TableDef
  Dim qDef                    As DAO.QueryDef
  Dim intNumDeletedItemsFound As Integer
  Set dbsDatabase = CurrentDb
  For Each tDef In dbsDatabase.TableDefs
      "This is actually used as a "Deleted Flag"
      If tDef.Attributes And dbHiddenObject Then
         strObjectName = FnGetDeletedTableNameByProp(tDef.Name)
         strObjectName = InputBox("A deleted TABLE has been found." & _
                         vbCrLf & vbCrLf & _
                         "To undelete this object, enter a new name:", _
                         "Access Undelete Table", strObjectName)

         If Len(strObjectName) > 0 Then
            FnUndeleteTable CurrentDb, tDef.Name, strObjectName
         End If
         intNumDeletedItemsFound = intNumDeletedItemsFound + 1
      End If
  Next tDef

  For Each qDef In dbsDatabase.QueryDefs
      "Note "Attributes" flag is not exposed for QueryDef objects,
      "We could look up the flag by using MSysObjects but
      "new queries don"t get written to MSysObjects until
      "Access is closed. Therefore we"ll just check the
      "start of the name is "~TMPCLP" ...
      If InStr(1, qDef.Name, "~TMPCLP") = 1 Then
         strObjectName = ""
         strObjectName = InputBox("A deleted QUERY has been found." & _
                         vbCrLf & vbCrLf & _
                         "To undelete this object, enter a new name:", _
                         "Access Undelete Query", strObjectName)

         If Len(strObjectName) > 0 Then
            If FnUndeleteQuery(CurrentDb, qDef.Name, strObjectName) Then
               "We"ll rename the deleted object since we"ve made a
               "copy and won"t be needing to re-undelete it.
               "(To break the condition "~TMPCLP" in future...)
                qDef.Name = "~TMPCLQ" & Right$(qDef.Name, Len(qDef.Name) - 7)
             End If
         End If
         intNumDeletedItemsFound = intNumDeletedItemsFound + 1
      End If
  Next qDef
  If intNumDeletedItemsFound = 0 Then
     MsgBox "Unable to find any deleted tables/queries to undelete!"
  End If

  Set dbsDatabase = Nothing
  FnUndeleteObjects = True
ExitFunction:
  Exit Function
ErrorHandler:
  MsgBox "Error occured in FnUndeleteObjects() - " & _
         Err.Description & " (" & CStr(Err.Number) & ")"
  GoTo ExitFunction
End Function


Private Function FnUndeleteTable(dbDatabase As DAO.Database, _
                 strDeletedTableName As String, _
                 strNewTableName As String)

  "Module (c) 2005 Wayne Phillips (http://www.everythingaccess.com)
  "Written 18/04/2005
  Dim tDef As DAO.TableDef
  Set tDef = dbDatabase.TableDefs(strDeletedTableName)
  "Remove the Deleted Flag...
  tDef.Attributes = tDef.Attributes And Not dbHiddenObject
  "Rename the deleted object to the original or new name...
  tDef.Name = strNewTableName
  dbDatabase.TableDefs.Refresh
  Application.RefreshDatabaseWindow
  Set tDef = Nothing
End Function

Private Function FnUndeleteQuery(dbDatabase As DAO.Database, _
                 strDeletedQueryName As String, _
                 strNewQueryName As String)

  "Module (c) 2005 Wayne Phillips (http://www.everythingaccess.com)
  "Written 18/04/2005
  "We can"t just remove the Deleted flag on queries
  "("Attributes" is not an exposed property)
  "So instead we create a new query with the SQL...

  "Note: Can"t use DoCmd.CopyObject as it copies the dbHiddenObject attribute!

  If FnCopyQuery(dbDatabase, strDeletedQueryName, strNewQueryName) Then
     FnUndeleteQuery = True
     Application.RefreshDatabaseWindow
  End If
End Function


Private Function FnCopyQuery(dbDatabase As DAO.Database, _
                 strSourceName As String, _
                 strDestinationName As String)

  "Module (c) 2005 Wayne Phillips (http://www.everythingaccess.com)
  "Written 18/04/2005
  On Error GoTo ErrorHandler:

  Dim qDefOld As DAO.QueryDef
  Dim qDefNew As DAO.QueryDef
  Dim Field As DAO.Field

  Set qDefOld = dbDatabase.QueryDefs(strSourceName)
  Set qDefNew = dbDatabase.CreateQueryDef(strDestinationName, qDefOld.SQL)

  "Copy root query properties...
  FnCopyLvProperties qDefNew, qDefOld.Properties, qDefNew.Properties

  For Each Field In qDefOld.Fields
      "Copy each fields individual properties...
      FnCopyLvProperties qDefNew.Fields(Field.Name), _
                         Field.Properties, _
                         qDefNew.Fields(Field.Name).Properties
  Next Field
  dbDatabase.QueryDefs.Refresh
  FnCopyQuery = True
ExitFunction:
  Set qDefNew = Nothing
  Set qDefOld = Nothing
  Exit Function
ErrorHandler:
  MsgBox "Error re-creating query "" & strDestinationName & "":" & vbCrLf & _
         Err.Description & " (" & CStr(Err.Number) & ")"
  GoTo ExitFunction
End Function

Private Function PropExists(Props As DAO.Properties, strPropName As String) As Boolean
  "Module (c) 2005 Wayne Phillips (http://www.everythingaccess.com)
  "Written 18/04/2005
  "If properties fail to be created, we"ll just ignore the errors
  On Error Resume Next
  Dim Prop As DAO.Property
  For Each Prop In Props
      If Prop.Name = strPropName Then
         PropExists = True
         Exit Function " Short circuit
      End If
  Next Prop
  PropExists = False
End Function

Private Sub FnCopyLvProperties(objObject As Object, OldProps As DAO.Properties, NewProps As DAO.Properties)
  "Module (c) 2005 Wayne Phillips (http://www.everythingaccess.com)
  "Written 18/04/2005
  "If properties fail to be created, we"ll just ignore the errors
  On Error Resume Next
  Dim Prop As DAO.Property
  Dim NewProp As DAO.Property
  For Each Prop In OldProps
      If Not PropExists(NewProps, Prop.Name) Then
         If IsNumeric(Prop.Value) Then
            NewProps.Append objObject.CreateProperty(Prop.Name, Prop.Type, CLng(Prop.Value))
         Else
            NewProps.Append objObject.CreateProperty(Prop.Name, Prop.Type, Prop.Value)
         End If
      Else
         With NewProps(Prop.Name)
              .Type = Prop.Type
              .Value = Prop.Value
         End With
      End If
  Next Prop
End Sub

Private Function FnGetDeletedTableNameByProp(strRealTableName As String) As String
  "Module (c) 2005 Wayne Phillips (http://www.everythingaccess.com)
  "Written 18/04/2005
  "If an error occurs here, just ignore (user will override the blank name)
  On Error Resume Next
  Dim i As Long
  Dim strNameMap As String

  "Look up the Unicode translation NameMap property to try to guess the
  "original table name... (Access 2000+ only - and doesn"t always exist?!)

  strNameMap = CurrentDb.TableDefs(strRealTableName).Properties("NameMap")
  strNameMap = Mid(strNameMap, 23) "Offset of the table name...

  "Find the null terminator...
  i = 1
  If Len(strNameMap) > 0 Then
     While (i < Len(strNameMap)) And (Asc(Mid(strNameMap, i)) <> 0)
       i = i + 1
     Wend
  End If
  FnGetDeletedTableNameByProp = Left(strNameMap, i - 1)
End Function
標簽: Access
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品国产精品国产偷麻豆| 在线看片一区| 国产一区福利| 成人午夜网址| 蜜桃视频在线网站| 超碰99在线| 91精品亚洲| 亚洲激情欧美| 亚洲一二三区视频| 视频一区日韩精品| 欧美精品中文| 三上亚洲一区二区| 欧美日韩水蜜桃| 国产99久久| 蜜臀精品久久久久久蜜臀| 欧美午夜三级| 另类欧美日韩国产在线| 国产精品精品| 亚洲韩日在线| 亚洲毛片在线免费| 久久精品一区二区国产| 日本少妇一区| 中文字幕一区二区av| 国产精品jk白丝蜜臀av小说| 91欧美在线| 一本一道久久a久久精品蜜桃| 亚洲香蕉久久| 国产精品xxx在线观看| 97精品国产福利一区二区三区| 亚洲福利久久| 日本一区二区三区视频在线看| 国产精品视频一区二区三区四蜜臂 | 久久久夜精品| 欧美中文字幕| 久久成人福利| 999精品一区| 日韩在线观看中文字幕| 精品午夜视频| 国产手机视频一区二区| 久久国产精品色av免费看| 国产一区精品福利| 国产免费成人| 国产精成人品2018| 免费不卡中文字幕在线| 欧美一级全黄| 91精品一区二区三区综合在线爱| 少妇精品久久久一区二区| 精品91福利视频| 香蕉久久久久久久av网站| 欧美激情五月| 亚洲综合国产| 福利欧美精品在线| 亚洲人成在线影院| 日韩av一级| 国产亚洲字幕| 三级在线看中文字幕完整版| 色狠狠一区二区三区| 伊人久久在线| 91成人在线网站| 美女毛片一区二区三区四区| 国产欧美自拍一区| 午夜国产精品视频免费体验区| 国产精品综合色区在线观看| 国产高清一区二区| 精品久久国产一区| 日本亚洲视频| 不卡av一区二区| 成人国产精品| 91精品国产一区二区在线观看| 日本精品在线中文字幕| 亚洲人成网站在线在线观看| 亲子伦视频一区二区三区| 国产精品久久久免费| 免费在线观看日韩欧美| 91精品国产乱码久久久久久久| 国产精品99久久久久久董美香| 石原莉奈一区二区三区在线观看| 日本在线高清| 麻豆精品在线| 亚洲精品看片| 中文亚洲欧美| 丝袜美腿一区| 精品国产中文字幕第一页| 日本一区二区三区视频在线看| 91精品成人| а√天堂8资源在线| 奇米狠狠一区二区三区| 亚洲制服少妇| 香蕉精品视频在线观看| 国产中文在线播放| 久久一区欧美| 国产精品亚洲综合久久| 日韩综合一区二区| 在线精品福利| 亚洲欧美日韩在线观看a三区 | 国产精品99精品一区二区三区∴| 亚洲三级网址| 狠狠爱www人成狠狠爱综合网| 欧美成人a交片免费看| 精品免费视频| 久久精品欧洲| 久久久久九九精品影院| 国产美女久久| 91欧美精品| 日本综合视频| 蜜桃一区二区三区在线观看| 午夜av一区| 免费人成精品欧美精品| 韩国三级一区| 裤袜国产欧美精品一区| 日本欧美大码aⅴ在线播放| 国产精品调教| 日本国产精品| 欧美一区三区| 欧美日韩一区二区三区视频播放| 日韩黄色在线观看| 久久精品一本| 亚洲播播91| 激情综合在线| 国产精品毛片久久| 国产乱论精品| 日韩精品国产欧美| 国产免费久久| 国产亚洲欧美日韩在线观看一区二区 | 久久激情中文| 久久国产免费| 亚洲第一精品影视| 欧美va亚洲va日韩∨a综合色| 亚洲午夜电影| 国产毛片久久| 色8久久久久| 国产美女精品视频免费播放软件| 国产精品777777在线播放 | 国产极品久久久久久久久波多结野| 91p九色成人| 久久av网址| 超级白嫩亚洲国产第一| 91精品蜜臀一区二区三区在线| 女人天堂亚洲aⅴ在线观看| 久久夜色精品| 国产精品尤物| 午夜电影一区| 国产精品一页| 亚洲涩涩在线| 亚洲精品99| 在线观看一区| 天堂va在线高清一区| 国产欧美一区二区三区国产幕精品 | 日本高清不卡一区二区三区视频| 久久精品青草| 免费在线观看视频一区| 国产亚洲精品美女久久久久久久久久| 麻豆91精品视频| 91精品一区国产高清在线gif | 日本一区二区免费高清| 99精品在线| 日韩一区精品字幕| 日本欧美一区二区| 精品视频在线观看网站| 国产91一区| 日本va欧美va瓶| 成人精品高清在线视频| 91精品91| 国产毛片久久久| 欧洲av不卡| 蜜臀av性久久久久蜜臀aⅴ流畅 | 欧美精品国产一区| 中文一区一区三区高中清不卡免费| 今天的高清视频免费播放成人| 综合亚洲自拍| 成人精品久久| 蜜臀久久99精品久久久久宅男 | 伊人精品一区| 日韩高清一区| 日本一区二区高清不卡| 蜜桃久久av| 日韩中文字幕视频网| 欧美亚洲国产激情| 精品国产乱码久久久久久樱花| 国产一区丝袜| 国产在线日韩精品| 国产欧美一区二区三区国产幕精品| 欧洲精品一区二区三区| 日韩中文字幕不卡| 蜜桃视频在线观看一区二区| 你懂的国产精品| 欧美aa国产视频| 国产精品一站二站| 首页国产欧美日韩丝袜| 欧美一区二区三区高清视频 | 免费在线播放第一区高清av| av亚洲一区二区三区| 国产精品久久久久9999高清| 91精品在线观看国产| 免费国产亚洲视频| 亚洲国产欧美日本视频| 欧美日韩1区| 日本在线成人| 成人午夜精品| 国产精品第十页|