Programming The VBA Editor describes methods for programmatically interacting with the VBE editor. Quote:"You can use these features to write custom procedures that create, change, or delete VBA modules and code procedures." The article is written for Excel but I think it should be adaptable to Access. (I haven't tried it yet- if you try it let me know how it works!)
Sunday, April 12, 2009
Programming The VBA Editor
Posted by Stephen at 6:00 AM | Permalink | I'm reading: Programming The VBA EditorTweet this! | Add This! | Blog This | 2 comments
Labels: vba
Saturday, April 11, 2009
Use WShell to Retreive the Path to Windows Special Folders
Sometimes in your program you'll need to find the path of the user's MyDocuments folder, or to the Desktop, or to the Favorites folder. Because different versions of Windows will place these folders in different places, it's important to ask Windows for the location of the file, instead of hard coding it or figuring it out from the user name.
This post describes a method for using the Windows Script Host to retrieve these names. The Microsoft documentation is here: SpecialFolders Property.
Here's an example of how to build a VBA function that uses this method within MS Access to find the path to the user's MyDocuments folder.
Posted by Stephen at 6:00 AM | Permalink | I'm reading: Use WShell to Retreive the Path to Windows Special FoldersTweet this! | Add This! | Blog This | 0 comments
Labels: special folders, vba, Windows Script
Friday, April 10, 2009
Decompiling an Access Database
Sometimes your database starts to exhibit unexplained behaviour- something that used to work suddenly stops working, or seemingly inexplicable errors appear. Or sometimes the database gets larger than it used to be (even after compact/repair) or starts to load much more slowly.
One of the solutions often recommended is to decompile the database.
Posted by Stephen at 6:00 AM | Permalink | I'm reading: Decompiling an Access DatabaseTweet this! | Add This! | Blog This | 3 comments
Thursday, April 9, 2009
The world's largest collection of connection strings on the Internet
Ran across this today: The world's largest collection of connection strings on the Internet.
If you want to use ADO you need connection strings. And if you want to access something outside your local Access database you may need to find the right syntax for the particular type of data you want to connect to. Carl Prothman has compiled sample connection strings for everything from Jet to AS/400 to MS Project to Oracle to.... You get the idea.
Posted by Stephen at 9:05 PM | Permalink | I'm reading: The world's largest collection of connection strings on the InternetTweet this! | Add This! | Blog This | 0 comments
Labels: ADO
Wednesday, April 8, 2009
The Normal Forms in a Nutshell
Good database design is key to success with application development in Access. The principles for database design in Access are the same as they are in any relational database, and one of the core principles is normalization. Within normaliztion there's a concept called "normal forms". Roger Carlson recently posted a series of articles that explain the normal forms. Take a look. It's a great way to get an introduction to this important concept.
Posted by Stephen at 8:06 PM | Permalink | I'm reading: The Normal Forms in a NutshellTweet this! | Add This! | Blog This | 0 comments
Labels: Database design, normalization
Tuesday, April 7, 2009
Accessing external data using the IN clause
Accessing external data using the IN clause. This article on the Microsoft Access Team Blog shows some of the ways to access data from outside your database by specifying the source of the data in the "In" clause of your query.
Quote:The other use of the IN keyword is as part of the SELECT statement or FROM clause, and is called the IN clause. The IN clause is used to access external data, and can be used in place of linked tables. For example, let's say that you had a SQL Server database that is used as part of an application, but you don't want to maintain a DSN to connect. You could use the IN clause in a query that uses a DSN-less connection to quickly read data from the external table.
It's one of those weird and wonderful things you can do in Access that many developers may never have tried!
Posted by Stephen at 8:00 PM | Permalink | I'm reading: Accessing external data using the IN clauseTweet this! | Add This! | Blog This | 0 comments
Saturday, April 4, 2009
Dymanic Forms: Moving Controls Along With The Tab Control They're Part Of
Lately I've built some really neat forms where the controls are moved based on the size of the form or in response to use input. It's not so hard to change the position of a control and it can make for a really well optimized user interface.
One of the particular challenges when moving controls is keeping the controls on a tab control in their proper place. If you move a tab control the controls on the tabs don't move on their own. A.D. Tejpal recently posted this sample database on Rogers Access Library that demonstrates enumerating the controls on each page of the tab control and moving them all so that they all stay together and stay in the right place on the tab control.
Posted by Stephen at 3:40 PM | Permalink | I'm reading: Dymanic Forms: Moving Controls Along With The Tab Control They're Part OfTweet this! | Add This! | Blog This | 1 comments
Labels: dynamic forms, forms, working example
Friday, April 3, 2009
Access 2007 Sample Database Demomstrating Cascading Combo Boxes
"I have two combo boxes on my form. When the user makes a choice in one I want the choices in the other on to change. For example the user will pick a country in the first combo box and the second combo box will now show only cities in that country. How do I do that?"
That's commonly called Cascading Combo Boxes and is one of the most commonly asked about techniques. I ran across a new article on this topic the other day. This a blog post from the Microsoft Access team that points out two different ways to get an Access 2007 sample database that demonstrates and explains two simple approaches to cascading combo boxes.
See also: all my Cascading Combo Box posts.
Posted by Stephen at 6:00 AM | Permalink | I'm reading: Access 2007 Sample Database Demomstrating Cascading Combo BoxesTweet this! | Add This! | Blog This | 0 comments
Labels: cascading combo boxes, forms, working example