Solved Access Database Locking Issue

Ajay289

New member
Local time
Today, 10:56
Joined
Mar 28, 2025
Messages
12
I am experiencing a persistent issue with Microsoft Access that is affecting multiple users in our environment. Specifically, when any database file is opened on four particular computers, it becomes locked, preventing access from any other users. Even after closing the application on these computers, the associated lock file remains and has to be manually deleted. To further investigate the issue, I created a dummy Access file with no data. Out of eight computers, four are experiencing the same locking issue with this dummy file. Additionally, when attempting to open the database file on these four computers while it is already in use elsewhere, I receive the error message: "Could not lock file." This problem does not occur when the database is accessed from the other computers, suggesting that the issue may be isolated to the specific machines.

I would appreciate any guidance or troubleshooting steps you could provide to help resolve this issue. Thank you for your assistance.
 
That suggests something to do with settings - probably being opened in exclusive mode as a default - in access on those machines go to file>options. Unlikely but if the app is being opened via a shortcut, check whether the exclusive flag is being set in the shortcut
 
I would make sure every user can both create and delete files in the folder containing the database. I usually have users right click to create a text file and then delete it after saving. If they can’t accomplish this, their permissions need to be changed.
 
That suggests something to do with settings - probably being opened in exclusive mode as a default - in access on those machines go to file>options. Unlikely but if the app is being opened via a shortcut, check whether the exclusive flag is being set in the shortcut
Thank you for your suggestion. I checked the options, and it's not set to open in exclusive mode by default. Additionally, I'm not using a shortcut to open the application.
 
I would make sure every user can both create and delete files in the folder containing the database. I usually have users right click to create a text file and then delete it after saving. If they can’t accomplish this, their permissions need to be changed.
Thank you for the suggestion. I tried creating and deleting files in the folder containing the database, and I didn't encounter any issues. It seems that the permissions are set correctly for the users.
 
Do each of the users have a copy of the FE on their computers which is then linked to the BE?
 
This is a permissions problem. Specifics will be tricky, but maybe I can point the right way. Here is a link that will go deeper than I can.


This link gives examples:


First, one would hope that this is a split database with individual front-end files for each user and the common back-end file that is shared.

Next, on ALL machines - ones that work fine and ones that don't - you need to know permissions for TWO files... the .ACCDB/.MDB file that is being shared and the folder that holds it. For each file, this determination is done starting with a right click >>Properties >> Security - which gets you to the Security control that has multiple parts. You will be comparing these settings. Stay with me on this description.

In the Security control panel, you will see a list of all "security identifiers" that have some kind of permission to use the file that you right-clicked. This list will include entries such as:
"Authenticated Users" (i.e. anyone validly logged in to that machine)
"SYSTEM" (windows internal code)
"Owner" which will be followed by "(machine name / username of the owner)"
"username (machine name / username )" - probably the name of the person logged in
"Administrators (machine name / Adminstrators)"
"Users (machine name/Users)"
- and you might have other possible entries like "Backup Operator" - but those I listed are the most common.

You will not usually have trouble with "Authenticated Users", "SYSTEM", "Owner", "Administrators", and "Users". Of these, "Authenticated Users", "Administrators", "Owner", and "Users" are pre-defined user or group identifiers that are generic in nature. SYSTEM is specifically any internal Windows code that has to run in user context. NOTE ALSO: If your site implements non-default (i.e. manually created) user groups, one or more of those groups CAN show up in the list - but might not show up everywhere, unlike the ones I listed earlier. On the other hand, if they are present, they follow the same rules as any other entry. FYI, that list of names is a literal readout of something that Windows calls an "Access Control List" or a "Discretionary Access Control List." The individual names are "Access Control Entries". If you need to look up more about them, use those names in your search.

Below that user/group list is a list of permission CATEGORIES (think of them as macro groups for the 14 known individual permissions.) One of the user name/group names will be highlighted/selected and the permission categories you see are for that selected user/group, with check-marks to show which ones are permitted and which ones are not. (Also watch out for DENY checkmarks!)

OK, here are some factors to consider. FIRST, when reading that list, it is a top-down list and ORDER IS IMPORTANT. If you qualify as a member of one of the pre-defined groups AND that group appears before (above) your username, then that group's permissions are used even if your name appears later in the list! FIRST MATCH WINS!!!

If you are in doubt, use the Advanced option in the Security Dialog box, take the Tab for Effective Permissions, and in that tab, pick a username - yours, for example. You will see the results of evaluating the access control list and this includes applying the list IN ORDER.

Of the permission categories, if you want to use Access, both the .ACCDB/.MDB file and the folder that contains it MUST have at least MODIFY permissions. MODIFY implies READ, WRITE, READ ATTRIBUTES, and a couple of other things for the DB file and ALSO implies CREATE and DELETE when working in the folder. YOU MUST HAVE MODIFY on both the DB file and its containing folder. The inability to delete a lock file indicates one of two situations - (a) file still open somewhere or (b) user attempting to delete it doesn't have permission to do so.

Now, the OTHER thing to consider. That "isolationist" locking MIGHT be from a DB setting. Check the front-end file that you distribute to your users to assure that in File >> Options >> Client Settings, scroll to "Advanced" and assure that the file is set to open shared rather than exclusive. But then the permissions can kick in here, too. IF a user CAN open the DB file but cannot CREATE the lock file (as would occur if the folder permissions were wrong), Access goes into a defensive posture that does an exclusive-open on the file.

Now, a note about users. A username is not really just, for example, "FRED". If FRED runs on the XDEPT003 machine, his login name (if locally managed) would be XDEPT003/FRED. IF FRED logis in to the ALLDEPT domain then his name might be ALLDEPT/FRED. The names that appear in the Access Control List will tell you where that person's account is defined because the machine name appearing in THAT list is where that user's account information is stored. This matters only in this sense: If XDEPT003/FRED or ALLDEPT/FRED is a username that Windows can verify, then FRED is an Authenticated User, and the order of ACL entries (ACEs) is significant if the desired permissions for FRED are different from the permissions found in the Authenticated Users list.

Normally you have to be a systems admin to change the order of an Access Control List. The CMD-prompt utility named ICACLS can manipulate the access control entry on a file but ALSO requires admin privileges.

It has been eight years and therefore I don't immediately recall the method we used to re-order ACL entries but there is a general rule about those entries. You want them to be in the order: Specfic Deny first, then Specific Allow, then General Deny, then General Allow. And watch out for those DENY cases because there is a rule that says "One DENY cancels a thousand ALLOWs."
 
Thank you for the suggestion. I tried creating and deleting files in the folder containing the database, and I didn't encounter any issues. It seems that the permissions are set correctly for the users.
Hi. Welcome to AWF!

You said you tried the suggestion. Does that mean you were one of the users affected by the locked Access database?
 
If it is only locked to other users when another user already has it open, I’m not sure read/write permissions to the back end folder is relevant?
when attempting to open the database file on these four computers while it is already in use elsewhere,
@Ajay289 - suggest you clarify exactly what your setup is. Is the db split? Where are the front ends located? Where is the back end located? And what type of server? What do you mean by ‘the database file’ ? Front end? Back end?
 
If it is only locked to other users when another user already has it open, I’m not sure read/write permissions to the back end folder is relevant?

@Ajay289 - suggest you clarify exactly what your setup is. Is the db split? Where are the front ends located? Where is the back end located? And what type of server? What do you mean by ‘the database file’ ? Front end? Back end?
I created empty access file with no data ,tables and form just and .accdb file and the file was locked.
 
Hi. Welcome to AWF!

You said you tried the suggestion. Does that mean you were one of the users affected by the locked Access database?
No i went to each of the computers where there was an issue and I created an new empty access file. When I tried to open it and close it the lock file remains. Also if the file is open it cannot be copied as well.
 
First, I want to sincerely thank you for your incredibly detailed and insightful response. Your explanation of security permissions, Access Control Lists, and how Access handles locking mechanisms was extremely helpful. I really appreciate the time and effort you put into it.After reviewing the security settings on all machines, I can confirm that the database file and its containing folder have the exact same permissions, user groups, and ordering across all systems. I also compared the security settings across both working and non-working instances, and there are no visible discrepancies.
One update: On the system that experiences the issue, even though the lock file is not automatically deleted after closing the database, I am able to delete it manually without any permission errors. Would this indicate that permissions are not the root cause, or could there still be some underlying issue preventing automatic deletion?
Again, I really appreciate your help! Looking forward to any further insights you may have.

1743494522136.png
 
No i went to each of the computers where there was an issue and I created an new empty access file. When I tried to open it and close it the lock file remains. Also if the file is open it cannot be copied as well.
Is MS your Access Updated? Do all the computters have the same MS Access version?
This behaviour you have explained was an ACCESS bug that happened 1 or 2 years ago!
 
Last edited:
I don’t believe you have ever stated where you are creating the file? From your permission screenshot, I would expect to see full control.
 
First, I want to sincerely thank you for your incredibly detailed and insightful response. Your explanation of security permissions, Access Control Lists, and how Access handles locking mechanisms was extremely helpful. I really appreciate the time and effort you put into it.After reviewing the security settings on all machines, I can confirm that the database file and its containing folder have the exact same permissions, user groups, and ordering across all systems. I also compared the security settings across both working and non-working instances, and there are no visible discrepancies.
One update: On the system that experiences the issue, even though the lock file is not automatically deleted after closing the database, I am able to delete it manually without any permission errors. Would this indicate that permissions are not the root cause, or could there still be some underlying issue preventing automatic deletion?
Again, I really appreciate your help! Looking forward to any further insights you may have.

View attachment 119177

The screenshot shows Read & Execute but not Modify. As previously mentioned, these listed names represent "levels" of permission that are comprised of 14 different specific permissions. Read/Execute is NOT adequate. Remember, the file in question and the folder in which it resides must BOTH have Modify checked or in effect for the person in question. I would have to unearth my security-class notes to find all of the implied permissions granted by Modify class permissions, but what you showed us is NOT correct. As to the ability to manually delete the lock file, the question is more complex.

When closing the DB does not delete the lock file, that is actually normal for a well-shared DB. ALL USERS must be out of the DB to get rid of that file. In practice, each user, when closing the DB, will try to delete the lock file. When other users still are working, the closing user gets "File Locked" - which is handled entirely by Access, you don't get involved in that case. The last user, however, should not see the internal error code "file locked." The other users DID get this error internally and just went away because Access expects that to happen. But the last user DOESN'T get that error and so the lock file IS deleted.

Access is using the file system - just as you are - to delete a file. Therefore, there is nothing "magic" about using either File Explorer or Access code to remove a file from the system. HOWEVER, Access is run by individual users who may have different permissions and different privileges. So there CAN be a difference in security context. My next question is, do you have Admin or other elevated rights that the other users don't have? Or are you the owner of the folder? There are "permission exceptions" and I just named two of them. The REAL question is this: For the user whose machine doesn't delete the file, can that user manually delete the lock file if nobody else is using the file?

There is another consideration: do any of your users terminate their session not by logging out but by turning off their machine? Because that leaves an unresolved lock "dangling" until someone comes along who can issue an UNLOCK or until the implied network link gets resolved by system time-outs or device-driver timeouts. As a former system administrator, I feel there is a special layer of Hell reserved for folks who end their business day by turning off their machine without logging out first.
 
No i went to each of the computers where there was an issue and I created an new empty access file. When I tried to open it and close it the lock file remains.
That means that the users don't have delete permission to the folder holding the file being opened.

If this is happening to the FE, then you are not distributing the application correctly. Each user MUST have his own physical copy of the FE. The FE is NEVER shared. Only the BE is shared.

There are two common ways to distribute the FE seamlessly.
1. Create a batch file and save it on the server. The batchfile copies the master copy of the FE from the server to the local PC and then opens it. The user is given a shortcut that runs the batch file.
2. There are multiple versions of access databases that handle copying the FE and checking its version.

I use #1 and use two tables - one in the FE and one in the BE - which are always compared when the app opens to ensure that the FE and BE are compatible.
 
The screenshot shows Read & Execute but not Modify.
Thank you for your detailed response. I will provide a clearer overview of the issue before addressing your suggestions.

Current Setup:

  • There are 10 Access database files, each corresponding to a different machine, all stored in a shared company folder.
  • Lets say Machine 1 is one of the computer experiencing the issue.

Observed Behavior:

  1. Issue on Machine 1:
    • If I open machine1.accdb on Machine 1, no other computer can open, copy, or access the file.
    • After closing the file on Machine 1, the lock file remains but can be manually deleted.
  2. Behavior on Other Machines:
    • If machine1.accdb is opened on Machine 2, it opens without issue.
    • Upon closing, the lock file is deleted automatically.
  3. Attempting to Open a Locked File on Machine 1:
    • If I try to open an Access file on Machine 1 that is already open on another machine, I receive a message stating that Access was unable to lock the file.

Addressing Your Suggestions:

  • Regarding Modify Permissions:
    • I understand your point about "Read & Execute" not being sufficient and that both the file and folder must have Modify permissions.
    • I will check and apply this setting.
    • However, if Modify were the issue, why do other machines (with the same folder access) not experience the same problem?
  • Answering Your Specific Questions:
    1. Can the user manually delete the lock file if nobody else is using the file?
      • Yes, the user can manually delete the lock file.
    2. Do any users turn off their machine instead of logging out?
      • I am not sure. The person who previously handled this issue reported facing the same problem.
      • To rule out file corruption, I created an empty Access database and tested it. The issue persists—any Access file opened on the affected machine locks the file.

Additional Observation:

On Machine 1, if the file is closed and the lock file is not deleted manually, another computer without issue can still open the database, even with the lock file present.
 
That means that the users don't have delete permission to the folder holding the file being opened.

If this is happening to the FE, then you are not distributing the application correctly. Each user MUST have his own physical copy of the FE. The FE is NEVER shared. Only the BE is shared.

There are two common ways to distribute the FE seamlessly.
1. Create a batch file and save it on the server. The batchfile copies the master copy of the FE from the server to the local PC and then opens it. The user is given a shortcut that runs the batch file.
2. There are multiple versions of access databases that handle copying the FE and checking its version.

I use #1 and use two tables - one in the FE and one in the BE - which are always compared when the app opens to ensure that the FE and BE are compatible.
Thank you for your suggestion regarding the distribution of the Front-End (FE) and Back-End (BE) in an Access database setup. I understand that having separate FE for each user and a shared BE can help avoid issues related to file permissions and ensure compatibility.

However, the issue I am encountering seems to be different. In the current setup, each system has only one Access file without linked tables, as everything is exported and imported directly. The problem arises when any Access file is opened on this particular system—it gets locked, and after closing the file, the lock file has to be manually deleted.

I appreciate your advice on creating a separate FE and a common BE, and I am working on modifying the setup accordingly. Nonetheless, the locking issue persists and appears to be unrelated to the FE/BE distribution method. If you have any insights or solutions specifically for the locking problem, I would be grateful for your assistance.
 
Is MS your Access Updated? Do all the computters have the same MS Access version?
This behaviour you have explained was an ACCESS bug that happened 1 or 2 years ago!
Thank you for your suggestion! All the computers are using MS Access 2016, which is part of Microsoft Office Professional Plus 2016. However, it's puzzling that only a few of them are experiencing this issue despite having the same version.
 
shared company folder.
So each user has a "<UserName>_Application name" front end is in the same folder on a server?
I'd suggest having the users in question copy it to their desktop and try running it from there to see if that fixes your issue. SHOULD be a very quick test.
 

Users who are viewing this thread

Back
Top Bottom