Solved

Access 2010 - What are hidden objecs? System Objects

Posted on 2013-06-06
15
650 Views
Last Modified: 2013-07-03
Can someone tell me what hidden and system objects are and some examples?
0
Comment
Question by:brothertruffle880
  • 7
  • 4
  • 2
  • +1
15 Comments
 
LVL 31

Accepted Solution

by:
Helen_Feddema earned 167 total points
ID: 39226683
System objects are tables used for internal purposes, such as the MSysObjects table that lists database objects and their properties.  They are usually hidden, because changes to them can cause serious problems.  They are sometimes used as sources for queries, especially in add-ins.  Hidden objects are ones you have chosen to hide (unless Hidden objects are made visible in the Options dialog).  You can hide an object by opening its properties sheet (from the Nav bar) and checking the Hidden checkbox.  This can be useful if you don't want users to see an object.
0
 
LVL 75

Assisted Solution

by:DatabaseMX (Joe Anderson - Access MVP)
DatabaseMX (Joe Anderson - Access MVP) earned 167 total points
ID: 39226691
Be default, all System  Objects are Hidden. These include any object (mainly tables) that start with the prefix MSys (like MSysObjects) or Usys (like USysRibbons).

You can unhide these ... Options>>Current Database >> Navigation.

You can also Hide any of your own objects as desired, by setting the Hidden attribute of the object ... Right Click >> Properties >> check the Hidden box.  
These will be then become Hidden when the Show Hidden Objects check box in the Navigation Options is Unchecked.

The idea is to keep users from seeing certain objects ... if say you are showing the Navigation Pane.

All MSys tables cannot be edited by anyone.  Read Only.

mx
0
 
LVL 57
ID: 39226705
any table prefixed with 'usys' will also be hidden unless "Show Hidden Objects" is checked in options.

Jim.
0
Migrating Your Company's PCs

To keep pace with competitors, businesses must keep employees productive, and that means providing them with the latest technology. This document provides the tips and tricks you need to help you migrate an outdated PC fleet to new desktops, laptops, and tablets.

 
LVL 75
ID: 39226725
:-)
0
 
LVL 31

Expert Comment

by:Helen_Feddema
ID: 39226824
USys objects (if any) are used for add-ins.
0
 
LVL 57
ID: 39226848
<<Sys objects (if any) are used for add-ins. >>

  Typically yes, but Access doesn't care really.  Any table can be hidden that way.

Jim.
0
 
LVL 75
ID: 39226874
But USys prefixed objects will be automatically hidden IF - the  "Show System Objects" is Unchecked - whether or not the Hidden attribute is check for that object.



mx
0
 
LVL 75
ID: 39226878
"USys objects (if any) are used for add-ins."

Except the USysRibbons table ... not related to an Add In.

I've used the USys prefix for many of my 'app system' tables for many years.

mx
0
 
LVL 57
ID: 39226932
<<Typically yes, but Access doesn't care really.  Any table can be hidden that way.>>

 Actually that goes for Msys as well.  

  One thing with the Hidden attribute, make sure you don't set the dbHiddenObject attribute on a table.  This is a JET level attribute and you will loose the table on the next compact and repair if it's set.

   This is different then using Application.SetHiddenAttribute, which sets the hidden attribute on the Access object (it's not a JET object attribute).

Jim.
0
 
LVL 75
ID: 39227126
Yeah ... that bug has been around a long time.
0
 
LVL 21

Assisted Solution

by:Boyd (HiTechCoach) Trimmell, Microsoft Access MVP
Boyd (HiTechCoach) Trimmell, Microsoft Access MVP earned 166 total points
ID: 39227882
@Jim and MX,

One thing with the Hidden attribute, make sure you don't set the dbHiddenObject attribute on a table.  This is a JET level attribute and you will loose the table on the next compact and repair if it's set.
Yeah ... that bug has been around a long time.

Most do not realized it was fixed in JET 4.

I have been using it with JET 4 databases for 10+ years and never lost a table after a compact.  I even use it to hide Linked tables in front ends.

If you use Application.SetHiddenAttribute  the object will show if you select show hidden objects.  It is exactly the same as selecting the Hidden attribute  check box in Table properties.
0
 
LVL 75
ID: 39227891
I kind of thought it was probably fixed.
0
 
LVL 21
ID: 39227982
It works fine in ACE (.accdb) databases also.

I use this with JET4 and ACE databases:

Public Sub HideTable(strTablename As String)
    With CurrentDb
        With .TableDefs(strTablename)
            .Attributes = .Attributes Or dbHiddenObject
        End With
    End With
    RefreshDatabaseWindow
End Sub
    
  
Public Sub UnHideTable(strTablename As String)
    With CurrentDb
        With .TableDefs(strTablename)
            If dbHiddenObject = (.Attributes And dbHiddenObject) Then
                .Attributes = .Attributes - dbHiddenObject
            End If
        End With
    End With
    RefreshDatabaseWindow
End Sub

Open in new window


from: How to Hide a table
0
 
LVL 57
ID: 39228733
I didn't think it was a bug per say, but a "by design" type of thing.   Didn't realize they had changed it.  I can't remember the last time I bothered to hide a table.

 Thanks for posting the correction!

Jim.
0
 
LVL 75
ID: 39229581
Exactly - at least by that method.
0

Featured Post

Migrating Your Company's PCs

To keep pace with competitors, businesses must keep employees productive, and that means providing them with the latest technology. This document provides the tips and tricks you need to help you migrate an outdated PC fleet to new desktops, laptops, and tablets.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I see at least one EE question a week that pertains to using temporary tables in MS Access.  But surprisingly, I was unable to find a single article devoted solely to this topic. I don’t intend to describe all of the uses of temporary tables in t…
Describes a method of obtaining an object variable to an already running instance of Microsoft Access so that it can be controlled via automation.
Familiarize people with the process of utilizing SQL Server views from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Microsoft Access…
In Microsoft Access, learn different ways of passing a string value within a string argument. Also learn what a “Type Mis-match” error is about.

786 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question