Access隐藏所有查询对象

2018-07-28 15:15:00
黄善超
原创
455

论坛有这样这个问题《如何用代码隐藏查询》。

为了发布MDE文件时隐藏全部的表提高安全性 ,使用以下代码隐藏表。

Dim tabDef As New TableDef
     Set dbs = CurrentDb
     For Each tabDef In dbs.TableDefs
             tabDef.Attributes = 1
     Next


在前面讲过的《Access彻底隐藏表对象》有提及,但是同样的代码用来隐藏查询是不行的。因为查询对象是没有Attributes对象。

可以利用下面的代码隐藏查询。

Sub HiddenQry()
    For Each qf In CurrentDb.QueryDefs
        If Left(qf.Name, 1) <> "~" Then
            Application.SetHiddenAttribute acQuery, qf.Name, False
        End If
    Next
End Sub


此时,查询所有对象不存在了

    分享