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

您的位置:首頁技術文章
文章詳情頁

access下如何恢復已經刪除的記錄;如何恢復已經刪除的表、窗體等等對象

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

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

 


回答:

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

建議:在建立數據庫結構時,可以在各個表中再多加一個 ISDEL 字段,刪除記錄時不使用 DELETE FROM ,而使用 UPDATE TABLE SET ISDEL=TRUE 這樣的語句,然后在界面上不顯示 ISDEL=TRUE 的記錄即可。
復制代碼 代碼如下:
如果還沒有被壓縮理論上可以。試試這段代碼吧。加在access模組中
恢復刪除的工作表(未被壓縮)
 
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
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美激情视频一区二区三区免费| 久久亚洲二区| 精品久久97| 黄色成人在线网址| 三上亚洲一区二区| 国产模特精品视频久久久久| 久久亚州av| 久久国产三级| 久久亚洲国产精品一区二区| 欧美男人天堂| 美女国产精品久久久| 视频国产精品| 中文一区二区| 日韩午夜在线| 1024精品一区二区三区| 精品视频一区二区三区在线观看 | 国产精品视频一区二区三区四蜜臂| 国产一区二区中文| 亚洲天堂资源| 国产高潮在线| 亚洲精品成人图区| 精品国产一区二区三区av片| 国产精品白浆| 亚洲一区欧美| 亚洲日韩中文字幕一区| 久久高清国产| 亚洲精品护士| 亚洲日本三级| 青青伊人久久| 国产精品一区二区精品| 日韩在线a电影| 好吊一区二区三区| 日韩亚洲在线| 亚洲欧美网站| 欧美成人基地| 国产韩日影视精品| 亚洲精品高潮| 国产精品三级| 国产精品第一| 四季av一区二区凹凸精品| 日韩伦理一区| 亚洲自拍另类| 国产美女高潮在线| 国产午夜久久| 久久字幕精品一区| 精品一区视频| 极品裸体白嫩激情啪啪国产精品| 日韩精品一级| 国产精品久久久久蜜臀| 欧美日中文字幕| 国产精品久久久久毛片大屁完整版 | 激情久久久久久| 日韩国产高清在线| 97精品国产福利一区二区三区| 欧美日韩激情在线一区二区三区| 蜜桃av一区二区在线观看| 国产精品xxx| 亚洲国产欧美日本视频| 精品亚洲免a| 久久裸体视频| 蜜臀av一区二区三区| 国产区精品区| 2023国产精品久久久精品双| 中文在线不卡| 精品不卡一区| 久久精品99国产精品| 五月激情久久| 国产精品嫩模av在线| 午夜欧美精品| 精品视频在线你懂得| 91欧美日韩| 在线免费观看亚洲| 日本一区二区免费高清| 亚洲三级欧美| 日韩av一区二区在线影视| 欧美日韩视频免费观看| 色综合视频一区二区三区日韩 | 欧美精品一区二区久久| 日韩高清一区| 亚洲成av人片一区二区密柚| 亚洲黄色网址| 久久久夜精品| 精品欧美激情在线观看| 尤物在线精品| 国产视频一区三区| 美女尤物久久精品| 日韩精品a在线观看91| 青青伊人久久| 国产精品二区不卡| 成人日韩在线观看| 9色国产精品| 亚洲一级高清| 99国产精品一区二区| 日韩精品第一区| 日韩理论视频| 国产一区二区三区黄网站| 另类小说一区二区三区| 日韩在线一区二区| 日韩在线观看一区二区| 在线亚洲国产精品网站| 免费黄色成人| 视频一区视频二区在线观看| 中文字幕一区二区三区在线视频| 国产精品va视频| 日韩一区二区三区免费播放| 国内精品麻豆美女在线播放视频| 国产精品毛片在线| 日本蜜桃在线观看视频| 久久成人精品| 天堂成人免费av电影一区| 午夜在线一区| 国产欧美日韩免费观看| 日韩一级网站| 亚洲激情偷拍| 色狠狠一区二区三区| 国产亚洲久久| 亚洲日本国产| 日本一区二区三区中文字幕| 999国产精品| 日韩欧美三区| 亚洲欧美成人综合| 黄色亚洲大片免费在线观看| 欧美专区18| 精品不卡一区| 欧美日韩一二| 亚洲日本三级| 日韩欧美高清一区二区三区| 国产乱码精品| 亚洲国内精品| 国产欧美激情| 99久久视频| 欧美永久精品| 极品日韩av| 国产精品一区二区三区av| 日韩精品91| 欧美精品中文| 日本高清不卡一区二区三区视频| 免费日本视频一区| 麻豆精品久久| 久久精选视频| 国产精品99久久免费观看| 一区二区三区四区日本视频| 久久国产直播| 日韩成人午夜精品| 亚洲一级少妇| 欧美亚洲自偷自偷| 午夜国产一区二区| 国产精品伦一区二区| 宅男在线一区| 亚洲网站视频| 99精品电影| 国产在线不卡一区二区三区| 婷婷综合福利| 美女一区网站| 国产乱码精品| 国产乱码精品一区二区三区亚洲人| 国产精品日韩欧美一区| 免费一区二区视频| 好吊视频一区二区三区四区| 老司机精品视频网| 日本一区二区高清不卡| 日韩精品中文字幕一区二区| 日本亚洲视频| 激情五月色综合国产精品| 亚洲a在线视频| 亚洲91久久| 一区免费视频| 国产欧美日韩影院| 香蕉久久久久久久av网站| 视频一区二区三区入口| 日韩和欧美一区二区| 狂野欧美性猛交xxxx| 伊人久久在线| 日本中文字幕不卡| 桃色一区二区| 国产精品啊v在线| 亚洲一区二区三区四区电影| 亚州av一区| 99亚洲视频| 免费看久久久| 国产亚洲精品v| 精品国产一区二| 蜜桃视频在线观看一区二区| 亚洲激情偷拍| 欧美成人亚洲| 国产精品久久国产愉拍| 韩国精品主播一区二区在线观看| 91精品二区| 日本免费在线视频不卡一不卡二| 蜜臀国产一区| 麻豆极品一区二区三区| 国产精品久久久久久久久妇女| 国产日韩欧美| 久久国产精品毛片| 成人片免费看| 97国产精品| 欧美三级网址| 久久天堂av| 播放一区二区| 国产精品白浆|