Jim Dettman
jimdettman at verizon.net
Mon Sep 13 15:00:33 CDT 2010
Great explanation Gary. I would only add that part of the debate to is that if you go the unbound route (and do all the work), then you have to ask why bother using Access at all with all of its quirks (I'm talking about install problems and references). After all, you can't do a 3 tier design with it and if your going the unbound route, your typically looking to do some type of n-tier design or client/server setup. Might as well use something else and get a whole heck of a lot more control, access to 3rd party controls, standalone EXE, etc. As far as the PK's, well...I don't quite agree. And I'm not going to get into it here as we've been over that ground many times. In fact I wrote an article for EE with my views on that subject. So if anyone cares to read it, it's here (I'm not 100% sure this will work though for non-members - they've been making a lot of changes lately): http://www.experts-exchange.com/viewArticle.jsp?aid=2041 Jim. -----Original Message----- From: accessd-bounces at databaseadvisors.com [mailto:accessd-bounces at databaseadvisors.com] On Behalf Of Gary Kjos Sent: Monday, September 13, 2010 3:32 PM To: Access Developers discussion and problem solving Subject: Re: [AccessD] The Famous Bound/Unbound Debate Hi Brad, Bound refers to using a record set, possibly a table or maybe a query as the record source for an Access Form. This has the advantage of letting Access take care of a lot of functionality. Unbound refers to not having a record source for the form and then using code behind the form to populate the various controls on the form. Doing this requires some amount of work to populate those fields, detect changes to them the user might make and then making the corresponding update to the records in the data tables. If you are using Access built in Jet Database as the data storage for the application and you don't have that many rows in your tables, most would agree that bound is the way to go. But maybe not ;-) If you use another database engine to store the data, perhaps SQL Server, it could be argued that it's much better to only retrieve the individual records you are wanting to display and or change and so doing that with code and then populating the controls on the form might be a better way to go. For many of us, it is a matter of preference in doing it one way or the other. Sometimes it might be better to do it one way and sometimes it might be better to do it the other way. I think that is the gist of it. I'm sure I will be corrected if I have miss-stated something or missed any key points. Another heated past debate was over the use of Natural Keys verses Surrogate Keys. A Surrogate key would be something like an Autonumber field, randomly or sequentially assigned by the database engine. A Natural Key would be something like a Social Security Number. In my opinion Natural Keys are similar to the use of GO TO in COBOL programs. There may be a place for them occasionally but generally they should be avoided. In my opinion. A system assigned unique key that identifies the record allows the field that would have been used as the key to be changed in the event that something happens to make that necessary. Perhaps a data entry error? Whatever. If you have other tables joined to that record on that natural key you are STUCK without doing some cascading update or something. GK On Mon, Sep 13, 2010 at 2:02 PM, Brad Marks <BradM at blackforestltd.com> wrote: > All, > > Compared to most of you, I am a relative newcomer to the world of > Access. > > Over the past few months, I have noticed a number of references to the > Bound/Unbound debate. It sounds like this was a really hotly contested > issue at one time and that now people almost joke about it. > > For us newcomers, it would be nice if someone could explain this issue > at a high level and perhaps spell out the major pros and cons of each > side of the debate. > > It is not my intent to start a Web-war, I would just like to better > understand what is going on here. > > Thanks, > Brad > > -----Original Message----- > From: accessd-bounces at databaseadvisors.com > [mailto:accessd-bounces at databaseadvisors.com] On Behalf Of Drew Wutka > Sent: Monday, September 13, 2010 1:53 PM > To: Access Developers discussion and problem solving > Subject: Re: [AccessD] SQL Server Express - true skinny > > Exactly. Which is part of the premise of the bound/unbound debate. > With unbound forms, where data is written in a split second chunk, the > stability of much higher user volume goes up tremendously! > > Drew > > -----Original Message----- > From: accessd-bounces at databaseadvisors.com > [mailto:accessd-bounces at databaseadvisors.com] On Behalf Of Jim Dettman > Sent: Friday, September 10, 2010 2:46 PM > To: 'Access Developers discussion and problem solving' > Subject: Re: [AccessD] SQL Server Express - true skinny > > Dan, > > That is more or less true, but the real bottle neck with a JET based DB > has > never been .LDB file operations. > > With JET, all processing is on the client side. The server acts as > nothing > more then a file share. > > The trick with keeping a connection open to the BE avoids the repeated > closing/opening of the LDB and DB files and all the associated overhead > with > removing/adding an active user under JET. Some apps benefit from that, > other not because they already maintain a connection one way or another. > The problem can be further compounded if the server has OPLOCKS on > (which > allows client side caching of files). JET doesn't need this as the > cache is > already on the client side. So it's simply a wasted effort on the > servers > part. And by default, OPLOCKs is enabled on Windows servers. > > The real restriction of JET is just one of stability. With no server > side > process to perform a rollback if a disconnect occurs, anytime that > happens > in the middle of write operations your fair game for corruption. So by > the > time you get past 30 or 40 stations, it's just hard to keep the > environment > stable. > > To prove that point, you can easily run a read-only/reporting JET based > app > with 200+ users without issues. > > It's not an issue of performance, but one of stability. > > Jim. > The information contained in this transmission is intended only for the > person or entity > to which it is addressed and may contain II-VI Proprietary and/or II-VI > Business > Sensitive material. If you are not the intended recipient, please > contact the sender > immediately and destroy the material in its entirety, whether electronic > or hard copy. > You are notified that any review, retransmission, copying, disclosure, > dissemination, > or other use of, or taking of any action in reliance upon this > information by persons > or entities other than the intended recipient is prohibited. > > > -- > AccessD mailing list > AccessD at databaseadvisors.com > http://databaseadvisors.com/mailman/listinfo/accessd > Website: http://www.databaseadvisors.com > > -- > This message has been scanned for viruses and > dangerous content by MailScanner, and is > believed to be clean. > > > -- > AccessD mailing list > AccessD at databaseadvisors.com > http://databaseadvisors.com/mailman/listinfo/accessd > Website: http://www.databaseadvisors.com > -- Gary Kjos garykjos at gmail.com -- AccessD mailing list AccessD at databaseadvisors.com http://databaseadvisors.com/mailman/listinfo/accessd Website: http://www.databaseadvisors.com