Jump to content

Recommended Posts

I have just started learning about PHP classes and want to start using them.  I am struggling with understanding the thought process behind classes and not so much the code.  What I mean is...Lets say I have a Gallery section on my website.  I want to create a class for this gallery.  The backend behind it is MySQL.  Here is where my confusing comes in and i hope someone can help me out.  My class will have a LOT of dependency on the tables and columns that i have setup in the DB.  To me this kills the re usability of the class.  When I use my class connected to DB-A all my methods for selecting Albums or Deleting photos work, but when I move to DB-B which has a slightly different Table/Column setup nothing in my Class will work.  I would potentially have to rewrite all my SQL statements to insure that I call the right tables/columns.

Is there a good approach for this?  Maybe some sort of Config class?  I hope I am not just missing something really obvious!
Link to comment
https://forums.phpfreaks.com/topic/32730-classes-thought-process/
Share on other sites

I have thought about that.  This is probably more of an opinion, but should I have reading and setting the config be part of the Class itself?  Maybe part of the constructor?  Or should I just read the config file with another function of possibly even another class and then pass those variables into my Gallery Class?
Use a separate class or namespace for interacting with the database.

For instance, let's say you are designing some type of catalog.  I would call the catalog class CCatalog.  CCatalog would be the access point into all dealings with catalogs for the rest of your site.  It would provide the methods to create, copy, move, modify, etc. a catalog.  There is also a good chance that catalogs would need to interact with the database.  For this I could create a separate class, or at least a namespace, called DAOCatalog or DBCatalog.  This namespace / class would be a collection of functions that interact with the database.

For instance, you might have a function DBCatalog::GetExistingCatalogs() that queries the database and the actual call to this function would be inside the CCatalog class.

Whenever I create a site, I consider the site itself to be like a top level object.  It deals with all sorts of classes CPage, CTemplate, etc. to create the content.  Those classes refer to other classes CUser, CAccount, CCatalog, etc. to work with and modify the content.  All of the database interactions are buried under another layer within data access objects (DAO).

Basically, whatever you do, I recommend separating the database interactions underneath another layer.
I took the Pear approach, just excluded the xml files etc.

I have a basic class that handles all of the db queries. then i have a file for each db table, in that file is a class and each method is a query. so if i want to get a list of users from my user table i call this method

userSQL::getList();
So, using this approach lets look at my Gallery example.  I would create a top level Gallery Class that defines all methods that interact with the database, such as Creating/Deleting albums and Creating/Deleting Images, etc and even maybe some private validation methods?  I could then create another Class called Photo.  This class would have methods for handling photos, i.e, resize them, generate a UID, generate a thumbnail, etc.  It would also contain a method that would add this photo to the database.  This method would simply call the method that I defined in my Gallery Class?  I am following you guys?  Am I on the right path here?  Thanks!
This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.