Joelle,

Joe's blog is back up.

http://clearsoftware.net/

Search for DAO, Bean, and Gateway on his blog, there's a search box in the right column, and you should get some very good reading material to get you started. Joe wrote the ModelGlue framework, so some of the material you find, especially some of the stuff on using beans, is mixed in with ModelGlue specific information, but you can by and large just ignore that for now and focus on the OO part.

By the way, you may want to take a peek at ModelGlue while you are there. Download the latest version of the framework and just look for the Quickstart tutorial in the release. It's very easy to follow and probably will help some in understanding OO basics, if only that you'll know a little more what Joe is referring to in his other writings when you see MG specific XML. An XML language can look daunting when you aren't familiar with it - but Joe's Quickstart makes it very easy to pick up.

:) Nando

Joelle Tegwen wrote:
Thanks.
I've been working on just writing what I need to get a certain job done and making things simple and generic. That seems to be helping me not get too overwhelmed with writing every possible bit of code under the sun.

I started with a simple Manager & ManagerHome system (someone was coaching me through the basics) but I think I will add a ManagerDao and a ManagerGateway. I've heard of "one click one action" and I'm starting to think that OO has kind of a "one function one action" phylosophy. I'll check out the link when his site comes back up though. Thanks

Joelle

Nando wrote:
Joelle,

It can take a while to get your head wrapped around OO. If you haven't read any introductory books, i'd definitely start there. That said, once you begin to understand the theory of it, you'll need to figure out how to practically apply it, and specifically in CF.

My number one tip is to keep your feet firmly on the ground. Stay practical. It's easy to imagine all kinds of Objects in your problem domain in the beginning and wonder how they are all related. Composition, Inheritance, Has A, Is A ...  Managers may own (have) Projects and Projects have Managers and Workers and Managers have Workers and Workers have Managers AND Assignments. How the hell do you model THAT??? It seems like a tangled mess.

Stay on the ground and take it one step at a time. When your application is editing a Project, is it editing a Manager /at the same time? /If the answer is no, then you most likely don't need to build that relationship into your model. Especially when you are just beginning. Use a Gateway Object (ManagerGateway) to fetch the Manager Names and ID's for your form, and take that foreign key and use your ProjectDAO to persist it in your database.

So for this little piece of your app, where you edit/add Projects, i'd use these objects:

Project - a bean to hold and pass around your Project data

ManagerGateway - a gateway object that just returns queries ...

ProjectDAO - an object specifically for persisting Projects to the database, with CRUD methods create, read, update, and delete.

There are more sophisticated approaches, but this would be a simple outline to follow to get you started. Beans, Gateways, and DAO's.

You would get the data for your reports from a Gateway. In essence, a Gateway simply wraps your queries in a function and makes it available to your whole application from one place.

AssignmentGateway.cfc could have a theoretical method called "getMyReport()" that returns a query that joins your Worker, Manager, and Assignment tables with an appropriate where clause. getMyReport could also take an argument, or several arguments (similar to passing an attribute into a custom tag) that modify the where clause of your query.

Joe Reinhart has some excellent tutorials on OO in CF on his site, http://clearsoftware.net/ (once he gets it back up again - you'll need to wait a day or so ... ).


----------------------------------------------------------
You are subscribed to cfcdev. To unsubscribe, send an email to [email protected] with the words 'unsubscribe cfcdev' as the subject of the email.

CFCDev is run by CFCZone (www.cfczone.org) and supported by CFXHosting (www.cfxhosting.com).

An archive of the CFCDev list is available at www.mail-archive.com/[email protected]





--


Aria Media Sagl
CP 234
6934 Bioggio
Switzerland
www.aria-media.com


Reply via email to