Solved

Mark Multiple Databases as Read Only at one time with VB

Posted on 2013-11-22
15
377 Views
Last Modified: 2013-11-26
Hello - What would code look like for me to set properties of multiple db's to Read Only at one time?  

For example, if I have a "Set Read Only" db that stored code I could run...and have it mark DB1, DB2, and DB3 as read only...?
0
Comment
Question by:CyHill
  • 5
  • 5
  • 5
15 Comments
 
LVL 13

Expert Comment

by:Surone1
ID: 39671288
just to be clear you want to set the read-only filesystem property of multiple .mdb files?
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39672933
You can do this with one Attrib command, since it allows you to use wildcards.

You can easily invoke this with the Shell function or using the Wscript.shell object's Run method.
0
 
LVL 13

Expert Comment

by:Surone1
ID: 39673467
i would have suggested Scripting.FileSystemObject but work got in the way. if you need details on how to make either of those work let us know.
0
Ransomware-A Revenue Bonanza for Service Providers

Ransomware – malware that gets on your customers’ computers, encrypts their data, and extorts a hefty ransom for the decryption keys – is a surging new threat.  The purpose of this eBook is to educate the reader about ransomware attacks.

 

Author Comment

by:CyHill
ID: 39675339
Okay...that helps to get me going.  I've never modified file properties in VB before, so this function is new to me.  

Would the code look something like this (see below)?  Feel free to simplify if I've added in things that are not necessary.
Function ToggleReadOnly()
   Dim fso, f
   Set fso = CreateObject("Scripting.FileSystemObject")
   Set f = fso.GetFile(c:\DB1)
   If f.attributes and 1 Then
      f.attributes = f.attributes - 1
      ToggleReadOnly = "Databases are Read/Write."
   Else
      f.attributes = f.attributes + 1
      ToggleReadOnly = "Databases are Read Only."
   End If
End Function

Open in new window

0
 
LVL 13

Accepted Solution

by:
Surone1 earned 200 total points
ID: 39675391
that code will make it read write if it is read only and read only if it is read write.
the filename should be between quotes as it is a string.

to just make it read only without checking:

 Set fso = CreateObject("Scripting.FileSystemObject")
    Set f = fso.GetFile("c:\DB1.mdb")
    f.Attributes = f.Attributes + 1
    Set f = Nothing
  Set f = fso.GetFile("c:\DB2.mdb")
    f.Attributes = f.Attributes + 1
    Set f = Nothing
   Set fso = Nothing
0
 

Author Comment

by:CyHill
ID: 39675438
Great - Thanks!

I will play with that today and to verify it works for me.

Question: If I wanted to make a second function to make teh databases read/write without checking (so basically the opposite of the other function)...would I simply change the line of code listed as "f.Attributes = f.Attributes + 1" (READ ONLY method) to "f.Attributes = f.Attributes -1" (READ WRITE method???)  Changing the "+ 1" to a "- 1"?  Would that do the trick?
0
 
LVL 13

Expert Comment

by:Surone1
ID: 39675445
yes it should
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39675729
Beware that if you run this against the same set of files twice, you will remove the read-only attribute.
0
 
LVL 13

Expert Comment

by:Surone1
ID: 39675765
aikimark is right. it also seems to affect the hidden property so we put the check back in:



 Set fso = CreateObject("Scripting.FileSystemObject")
    Set f = fso.GetFile("c:\DB1.mdb")
 If f.Attributes And 1 Then
       Else
    f.Attributes = f.Attributes + 1
end if
    Set f = Nothing
  Set f = fso.GetFile("c:\DB2.mdb")
 If f.Attributes And 1 Then
       Else
    f.Attributes = f.Attributes + 1
end if
    Set f = Nothing
   Set fso = Nothing


and



 Set fso = CreateObject("Scripting.FileSystemObject")
    Set f = fso.GetFile("c:\DB1.mdb")
 If f.Attributes And 1 Then
  f.Attributes = f.Attributes - 1
       Else
 
end if
    Set f = Nothing
  Set f = fso.GetFile("c:\DB2.mdb")
 If f.Attributes And 1 Then
  f.Attributes = f.Attributes - 1
       Else
   
end if
    Set f = Nothing
   Set fso = Nothing
0
 

Author Comment

by:CyHill
ID: 39675791
Yeah...I noticed that it wanted to mark the DBs hidden if I ran it more than once.  

Below is what I came up with...instead of adding or subtracting a number to the exisitng Attritbute property...just set it to the settign I want (e.g. from  f.Attributes = f.Attributes + 1 to  f.Attributes = 1)

Do you see any reason why this will not work?  Seems to work when testing.


Function DBS_ReadOnly()
Set fso = CreateObject("Scripting.FileSystemObject")
    Set f = fso.GetFile("H:\TEST\db1.accdb")
    f.Attributes = 1
    Set f = Nothing
  Set f = fso.GetFile("H:\TEST\db2.accdb ")
    f.Attributes = 1
   Set fso = Nothing
End Function

Function DBS_ReadWrite()
Set fso = CreateObject("Scripting.FileSystemObject")
    Set f = fso.GetFile("H:\TEST\db1.accdb")
    f.Attributes = 0
    Set f = Nothing
  Set f = fso.GetFile("H:\TEST\db2.accdb ")
    f.Attributes = 0
    Set f = Nothing
   Set fso = Nothing
End Function

Open in new window

0
 
LVL 45

Expert Comment

by:aikimark
ID: 39675846
Instead of using addition, use the AND boolean operator to flip the one bit.

Have you considered my suggestion of the use of the Attrib command?
0
 

Author Comment

by:CyHill
ID: 39675896
aikimark - is there a reason why this wouldn't work...or is not a "correct" option to go with?  

settign the attribute to the exact setting I want (e.g. Attributes = 1 or Attributes = 0)?  


Function DBS_ReadOnly()
Set fso = CreateObject("Scripting.FileSystemObject")
    Set f = fso.GetFile("H:\TEST\db1.accdb")
    f.Attributes = 1
    Set f = Nothing
  Set f = fso.GetFile("H:\TEST\db2.accdb ")
    f.Attributes = 1
   Set fso = Nothing
End Function

Function DBS_ReadWrite()
Set fso = CreateObject("Scripting.FileSystemObject")
    Set f = fso.GetFile("H:\TEST\db1.accdb")
    f.Attributes = 0
    Set f = Nothing
  Set f = fso.GetFile("H:\TEST\db2.accdb ")
    f.Attributes = 0
    Set f = Nothing
   Set fso = Nothing
End Function
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39675955
As written, you are setting the Attributes of these files without any regard to other attributes, such as archive-needed.

Earlier comment correction:  The OR boolean operator should be used, not the AND operator.
0
 

Author Comment

by:CyHill
ID: 39679507
aikimark - can you show me an example of what the code would look like if using the Attrib command?
0
 
LVL 45

Expert Comment

by:aikimark
ID: 39679762
attrib +r H:\TEST\db*.accdb

Open in new window

0

Featured Post

Live: Real-Time Solutions, Start Here

Receive instant 1:1 support from technology experts, using our real-time conversation and whiteboard interface. Your first 5 minutes are always free.

Question has a verified solution.

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

Experts-Exchange is a great place to come for help with solutions for your database issues, and many problems are resolved within minutes of being posted.  Others take a little more time and effort and often providing a sample database is very helpf…
If you need to start windows update installation remotely or as a scheduled task you will find this very helpful.
In Microsoft Access, learn the trick to repeating sub-report headings at the top of each page. The problem with sub-reports and headings: Add a dummy group to the sub report using the expression =1: Set the “Repeat Section” property of the dummy…
With Microsoft Access, learn how to start a database in different ways and produce different start-up actions allowing you to use a single database to perform multiple tasks. Specify a start-up form through options: Specify an Autoexec macro: Us…

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