I'm considering building a MS Access front-end for an Oracle database.
I'm not a developer (I'm a public works guy), but I do know my way around MS Access and Oracle. The number of users would be 5, possibly growing to 10-20. The front end would be mostly reports, with the odd form for data entry. Security isn't a primary concern; that's handled by the database, and the information isn't sensitive.
I'm aware that MS Access projects often end up being disastrous monstrosities. As far as I know, MS Access is not meant to be an enterprise system.
Yet I'm considering it, because, well, I don't have any other options. I'm not in I.T., and my I.T. department simply doesn't have the resources to help. And in my organization, a proper, enterprise, out-of-the-box system is 5-10 years away. I can't wait that long. Instead, I have MS Access to work with.
I'm hoping that if I stick to a few key principles, that the front-end won't end up as a fragile, disastrous monstrosity, but rather be a sustainable and robust system.
I'm hoping to:
- Keep it as simple as humanly possible. If functionality isn't absolutely necessary, then don't implement it. Force stakeholders to justify their requests.
- Consider it only as a prototype, not as a formal enterprise system. Make all stakeholders solemnly swear to eventually migrate it to a proper enterprise system.
- Configure, don't customize. Only customize (VBA) as an absolute last resort. Even then, consider not doing things, before resorting to customization. I say this, because I'm the only one in the office who knows how to script, and I'm not even that good at it.
- Hold regular 'fire drills'. If it breaks, and I'm not around to help, what will happen? Hold regular training/knowledge sharing sessions to teach colleagues about the system.
- Tend to the system as if I were tending to a garden. Stay on top of things. Continuously improve it by making it simpler, more efficient, and remove unnecessary functionality.
With all this said, even if I manage to do these things, I'm guessing that there are still problems associated making an enterprise system in MS Access.
What are the risks and inherent problems associated with an enterprise MS Access front-end?
Firstly, you should give yourself credit! You definitely don't sound inexperienced; quite the contrary. Your approach to building and maintaining a system sounds top notch. Regarding your limitation, it sounds like you need a reporting tool, and it sounds like Access is your only option. I know there is a comment here that suggests Oracle Apex, but I assume that is not an option for you. A product using native access methods to Oracle would most certainly perform better rather than Access, but that doesn't mean you have hit a dead end. Access is a powerful tool if you understand its limitations (and by that, I don't just mean the 2GB file size limit; I doubt you would run into that). Here are a few of suggestions that I can offer, and hopefully this doesn't sound foreign: