|
Sorry for the repost, I forgot to change the topic... Walden, >And if I replace the "new iDB2Connection(sCS)" part with a call to a >class factory that returned whatever type of connection I needed, I may >be able to work with provider-specific objects in a generic way. >However, while I complied the above code to see if it was syntatically >correct, I've _NOT_ tried to use it at all. I may have all sorts of >problems actually trying to assign different connection objects to the >generic interface. This is very similar to what I had in mind. Imagine a database file, either in SQL Server, Oracle, or iSeries. Naturally, I want to encapsulate DB access to the file in a class. Now, I need 3 different approaches because of the 3 different .NET providers, but I want to hide that detail from anyone using the class, so I was thinking that the "encapsulating class" would actually be a wrapper of some sort: callingClass => wrapperClass { looks in Config for DBAccess Type } => OracleDB || iSeriesDB || SQLServerDB Since these methods implement the same interface, I should be able to issue commands and pass DataSets back and forth in the wrapper class. All the properties would be in the wrapperClass, who acts as an agent for the DBAccess classes. Now all of my calling code always uses the same class for file access, and the implementation is masked inside the standard "CRUD" methods. It's just a thought I've been toying with, I certainly don't have it crystallized yet. Any input would be appreciated. Joel http://www.rpgnext.com P.S. My BP is supposed to be ordering the CA refresh for V5R3. The beta download has "expired", even though IBM still has a bunch of pages dedicated to it...
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.