mikebernat.com en-us http://www.mikebernat.com Web-Development, Design, Usability How SHOULD developers answer questions? http://www.mikebernat.com/blog/How_SHOULD_developers_answer_questions? <p>A natural continuation from my last post <em><a href="http://mikebernat.com/blog/How_Do_GOOD_Developers_Ask_Questions?">How do GOOD Developers Ask Questions?</a></em>: How do good developers answer questions? When given a very specific question that you know has a very specific answer, your first reaction might be to blurt out the answer and be done with it. However, I like to go the extra step and ask what they've tried so far or what research they've done.&nbsp; I like to show them how to arive at the answer on their own as well as <strong>provide the solution</strong>. The old 'Give a man a fish and he eats for a day, teach him to fish and he eats for a lifetime.' Allowing one to do personal research leads to an infinite amount of additional knowledge compared to spoon-feeding code to others.</p> <p>Ofcourse this doesn't apply to simple quick-reference type questions where you know full-well that the asker is capable of finding the solution on their own but are asking you to save time. <strong>AVOID PISSING OFF THE ASKER BY BEING CONDESCENDING OR ANNOYING</strong>.</p> 10/27/2009 7:30pm How Do GOOD Developers Ask Questions? http://www.mikebernat.com/blog/How_Do_GOOD_Developers_Ask_Questions? <p><span>I spend a lot of time on&nbsp;</span><a href="http://stackoverflow.com/"><span style="font-size: x-small;">stackoverflow.com</span></a><span style="font-size: x-small;">&nbsp;and I've seen my fair share of questions. Some good, others leave you wondering how the hell some people made it this far. Good developers have learned how to ask questions to get the best possible answer in the shortest amount of time.</span></p> <p><span>First of all, let me say this. If you consider yourself a developer and don't find yourself wanting to ask questions on a daily basis, you're doing something wrong. Asking questions without being afraid of humiliating yourself is critical.&nbsp;</span></p> <p><span>Let me throw out a few pointers that I've gathered from reading hundreds (if not thousands) of different questions on sites like stackoverflow,&nbsp;</span><a href="http://www.experts-exchange.com/"><span style="font-size: x-small;">experts-exchange</span></a><span>, and other various forum-type sites.</span></p> <p>&nbsp;</p> 10/7/2009 11:30am Wildflower CMS and Unterminated String Literal Error http://www.mikebernat.com/blog/Wildflower_CMS_and_Unterminated_String_Literal_Error <p><span>I've been developing a site using <a href="http://wf.klevo.sk/">Wildflower CMS</a> developed using <span>CakePHP</span> and ran into an infuriating problem. After working on it for several weeks without issue I started receiving javascript errors that caused everything to come to a grinding halt. The errors were all reported using Firebug and the javascript debugger. The culprit:</span></p> <p><span style="color: #ff0000;">Unterminated String Literal</span></p> <p><span style="color: #000000;">After that</span> in the Firebug console was:</p> <p><span style="color: #ff0000;">$ is not defined</span></p> <p>I knew there was a strong possibility that the first error was somehow causing the second and that top-down debugging was the way to go. After inspecting the javascript code I discovered that there was a variable assignment going on that spanned several lines. This might be legal in PHP but not javascript. </p> 3/23/2009 8:00pm Taking a ride down the sunshine highway http://www.mikebernat.com/blog/Taking_a_ride_down_the_sunshine_highway <p><img style="border: 0pt none; background: #ffffff none repeat scroll 0% 0%; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial; float: right;" src="http://www.mikebernat.com/images/newcitymedia.jpg" border="0" alt="New City Media" width="153" height="58" />I just wanted to let everyone know that there is a big change coming up in my life. After much thought, discussion, and stress I have decided to leave <a href="http://www.newcitymedia.com">New City Media</a>. I've lived here in <a href="http://maps.google.com/maps?f=q&amp;source=s_q&amp;hl=en&amp;geocode=&amp;q=Blacksburg,+VA&amp;sll=37.0625,-95.677068&amp;sspn=47.704107,79.101563&amp;ie=UTF8&amp;z=12">Blacksburg, VA</a> for nearly six years and worked at NCM for two of them. The family-like-culture, environment, and surroundings made this a nearly impossible decision to make. I had the opportunity to work with industries in nearly every walk of life. From small family-owned companies to billion-dollar corporations. Tourism, real-estate, jewelery, industrial manufacturing, education, world-wide non-profits, biotechnology, New City Media gave me the opportunity to be a part of all of these.</p> <p><img style="border: 0pt none; background: #ffffff none repeat scroll 0% 0%; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial; float: left;" src="http://www.mikebernat.com/images/0c4c455.jpg" border="0" alt="NFi Studios" width="80" height="80" />I have accepted an offer to join the <a href="http://www.nfistudios.com/">NFi Studios</a> Interactive Team. NFi develops and maintains several products including <a href="http://www.memberfuse.com/">MemberFuse</a>. They are located in downtown Orlando, FL which means I will be making my triumphant return to the sunshine state. I spent 9 years in Jacksonville, Florida before moving up here to Appalachia. The office environment and culture at NFi appears to be very relaxed and informal, much like NCM. </p> <p>I'm excited to be working with web-application type projects. NFi uses the Zend Framework for their enterprise applications. I had the opportunity to take a peak under the hood of one of their projects and was blown away by the quality of their work. I can't wait to get down there and join the team.</p> <p>Working for New City Media has left me tainted. I've come to realize that I will never be able to work for Corporate-America because of the environment that <a href="http://www.newcitymedia.com/team/poteet/">David Poteet</a>, president NCM, has developed. The first thing I found myself asking companies about was their office environment. Everyone here has been wonderful to me in good times and bad, and I will never forget these last two years. </p> <p>I'll be moving to Orlando (east side) this weekend and can't wait to jump into the geek-community. </p> <p><strong>If anyone has any tips, suggestions, or interesting tidbits about the area, happenings, or anything else you think would be useful for my situation please share them</strong>.</p> <p>&nbsp;</p> 3/3/2009 5:00pm Zend Certified! http://www.mikebernat.com/blog/Zend_Certified! <p><a href="http://www.zend.com/en/store/education/certification/yellow-pages.php#show-ClientCandidateID=ZEND009811"><img style="border: 1px solid black; background: #ffffff none repeat scroll 0% 0%; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial; float: right;" src="http://www.mikebernat.com/images/zend_certified.gif" border="0" alt="Zend Certified Engineer" width="73" height="68" /></a>I passed the <a href="http://www.zend.com/en/services/certification/php-5-certification/"><span><span>Zend</span></span> PHP5 Certification</a> Exam last week and thought I would share my experience with it. </p> <p><a href="http://www.zend.com/en/store/education/certification/yellow-pages.php#show-ClientCandidateID=ZEND009811">Zend Yellow Pages</a></p> <p>I decided that I wanted to take the test about 2 1/2 months ago. The first thing I did was visit the site and learn more about the exam itself. I discovered it covers almost every facet of the language and its use. Here is a breakdown of the major sections:</p> <ul> <li>PHP Basics</li> <li>Functions</li> <li>Arrays</li> <li>Object Oriented Programming</li> <li>Security</li> <li>XML &amp; Web Services</li> <li>Strings &amp; Patterns</li> <li>Databases &amp; SQL</li> <li>Web Features</li> <li>Streams &amp; Network Programming</li> <li>PHP 4/5 Differences</li> <li>Design &amp; Theory</li> </ul> <p>You can get a more details topic list for each section on the <a href="http://www.zend.com/en/services/certification/php-5-certification/">PHP5 Certification Landing Page</a>. </p> <p>For the first month I spent time reading e-books and other free material on the subjects mentioned above that I felt weak in. I was not very devoted during the first month and only spent a couple hours (3-5) each week. </p> <p>At the beginning of the second month, I purchased two books recommended by a lot of others who passed the exam.</p> <h3><a href="http://www.amazon.com/gp/product/0672327090?ie=UTF8&amp;tag=mikebernatcom-20&amp;linkCode=as2&amp;camp=1789&amp;creative=390957&amp;creativeASIN=0672327090"><em><span><span>Zend</span></span> PHP Certification Study Guide</em> - <span><span>Zend</span></span> Technologies</a><br /> </h3> <p><a href="http://www.amazon.com/gp/product/0672327090?ie=UTF8&amp;tag=mikebernatcom-20&amp;linkCode=as2&amp;camp=1789&amp;creative=390957&amp;creativeASIN=0672327090"><img style="border: 1px solid black; background: #ffffff none repeat scroll 0% 0%; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial; float: left;" src="http://www.mikebernat.com/images/zend_1.jpg" border="0" alt="Zend PHP Certification Study Guide" title="Zend PHP Certification Study Guide" width="125" height="160" /></a>The first book is published by <span><span>Zend</span></span> and is 'the official study guide to prepare for the <span><span>Zend</span></span> PHP Certification exam'. I liked this book because it was very focused and clear about the topics it was covering. It also has a couple of practice questions at the end of each chapter to prepare you for the real thing. </p> <p>There is also a glossary of terms that help you become familiar with some of the terminology used. Not sure what a HEREDOC or MTA is? Look it up quickly with this book.</p> <p>This book does have a few technical errors in some examples that you do need to watch out for. </p> <p>&nbsp;</p> <h3><a href="http://www.amazon.com/gp/product/0973862149?ie=UTF8&amp;tag=mikebernatcom-20&amp;linkCode=as2&amp;camp=1789&amp;creative=390957&amp;creativeASIN=0973862149"><em><span><span>Zend</span></span> PHP Certification Study Guide 2nd Edition</em> - Davey <span><span>Safik</span></span> and Ben Ramsey</a></h3> <p><a href="http://www.amazon.com/gp/product/0973862149?ie=UTF8&amp;tag=mikebernatcom-20&amp;linkCode=as2&amp;camp=1789&amp;creative=390957&amp;creativeASIN=0973862149"><img style="border: 1px solid black; background: #ffffff none repeat scroll 0% 0%; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial; float: left;" src="http://www.mikebernat.com/images/zend_2.jpg" border="0" alt="Zend PHP 5 Certification Study Guide" title="Zend PHP 5 Certification Study Guide" width="130" height="160" /></a>I actually started reading this book first. This book contains more information about each topic but seems less focused. What I mean is that the major topics are covered and explained fairly well but it doesn't go as in-depth when it comes to sub-topics. I frequently caught myself going to this book when I needed more general information about something but tended to stay with the aforementioned book because it helped me stay focused.</p> <p>This book does not contain any practice questions or glossary, which is a bummer.</p> <p>&nbsp;</p> <p>&nbsp;</p> <h3 class="alt"><a href="http://www.zend.com/en/store/php-certification/online-practice-testing"><span><span>Zend</span></span> PHP 5 Certification Online Practice Testing</a></h3> <p>My last resource was the online practice tests made available <span><span>Zend</span></span>. They are in the same format as the real test: 70 questions with a 90 minute timer. The layout of the actual test is a little different than these practice tests but nothing significant. The advantage to these practice tests is that you can go on past the 90 minutes and it will give you two scores. One when the time expired and the other is based on the final submission. </p> <p><strong>It's important to note that the practice tests do not tell you how you did on each question</strong>. Rather it breaks the test down into each major section and gives you one of three scores - fail, pass, or passed with flying colors. I found this to be very annoying but understood the intended benefit. </p> <p>I took a total of 5 exams out of the 10 that I purchased. After the 5th exam a significant number of questions were repeats which really took away from the 'fear' and 'anxiety' factor of the test. I heavily recommend you take the test until you pass with flying colors in each major section to be ready for the real thing.</p> <p>&nbsp;</p> <h3>Overview</h3> <p>It's been mentioned before and I agree that none of these resources alone are enough to make you feel confident going into the test. Rather, a combination of each resource should be taken advantage of to feel fully prepared. I took every practice question in <span><span>Zend's</span></span> book twice and read the entire book two or three times total. I spent a good deal of time in PHP Architect's book but probably only read it front-to-back once. </p> <p>I consider the practice test to be the most beneficial. I took one test almost immediately after I purchased them to have a baseline benchmark. With a general idea of where I stood in each section I was able to concentrate my studying in those sections. After I was satisfied that I had improved I retook the test and repeated the process until I passed every section with flying colors. </p> <p>Even with this I still considered the real test to be difficult. The practice test claims to be generally harder than the exam - In my opinion, this is not true. </p> <p>The style of questions was very test-like. They were very obscure blocks of code that obviously had no real-world use but still covered several very important concepts. There are four types of questions: </p> <ul> <li>Single choice questions - Multiple choice, choose one</li> <li>Multiple choice questions - Multiple choice, choose several</li> <li>Fill in the blank questions - Several blanks in a sentence, choose from multiple possible answers</li> <li>Open questions - fill in the blank (text input)</li> </ul> <p>&nbsp;</p> <h3>Test Day!<br /> </h3> <p>The test was observed by a proctor at a Pearson <span><span>Vue</span></span> testing center of my choice. They took all my belongings and stored them in a secure area (unlocked closet), sat me down in front of a computer, and gave me a laminated sheet of legal-length paper with a dry-erase marker (no eraser, although I'm sure I could have asked for one). The proctor starts the exam and after a few screens explaining the rules, agreeing to a NDA, andmaking sure I was ready, the test began. </p> <p>I can't really talk much about the test or specific questions that were asked but I can say that they were from every topic. A good variety of mixed-up questions. I don't believe it was the type of test where the questions adjusted themselves based on whether or not you answered correctly or not. It is important to note that <strong>there are trick questions</strong>. </p> <p>I found these questions in the book, practice exam, and the exam itself. There would be large blocks of code that would never get executed because of some small detail. I don't believe they are intended to be tricky just for the sake of amusing the test-authors, rather to see if you really pay attention to details in the code. I think we can all agree that attention to detail is of utmost importance in this profession. </p> <p>Once you have completed all 70 questions you are presented with a chance to go back to any particular question and re-evaluate your answer. Once you're satisfied with your performance you submit the test for grading. After a couple seconds (seemed like days) of plugging and chugging you get a screen with either Pass or Fail. The proctor hands you a printed certificate with your candidate number, grade, and sends you on your way.</p> <p>&nbsp;</p> <h3>Tough Subjects</h3> <p>These were the toughest subjects for me because I do not use them very often:</p> <ul> <li><span><span>Bitwise</span></span> operators.</li> <li><a href="blog/PHP_Data_Types_-_Octal_Notation">Data Types</a><br /> </li> <li>XML &amp; Web Services.</li> <li>Type Hinting<br /> </li> <li>Database topics - PDO, <span><span>mysqli</span></span>, transactions, and other database technologies.</li> <li>A lot of functions. I had to memorize a lot of functions that I forgot about or used often yet never seemed to remember the parameter order or particular definition. I've become conditioned to pull up the PHP manual and look something up in my sleep. The function you need to know pulled from every corner of PHP. Strings, arrays, files, and network streams just to name a few.</li> <li>Nuances of <span><span>PHP's</span></span> variable juggling.</li> <li>And more!</li> </ul> <p>&nbsp;</p> <h3>Conclusion</h3> <p>I spent a lot of time studying at my leisure but really buckled down the last two weeks leading up to the exam. As I said before, none of the resources I found are enough to make you feelconfident going into the test. Rather, all of them together do a nice job preparing you. There are a lot of questions on subjects that you probably have never used in the past and may never use in the future. I recommend spending some extra time as you may have to memorize several key functions and their parameters for the exam.</p> <p>I'm glad I spent the time and effort to earn the certification. I know that there are those out there who question its usefulness but I found it extremely helpful. Not only do I find myself more confident in my abilities to use the language properly, but I get to use the <span><span>Zend</span></span> logo on my site :)</p> <p>&nbsp;</p> 2/9/2009 4:00pm Feedburner - Account Moving Headaches http://www.mikebernat.com/blog/Feedburner_-_Account_Moving_Headaches <p>So, if you didn't know already, I use <a href="http://www.feedburner.com">Feedburner</a><span> for my article feeds. They have a lot of really awesome features and I have been happy with their service thus far. A year or two ago, Google boughtFeedburner and provided everyone free upgrades to their 'Pro' package. However, just recently they started migrating the Feedburner accounts to Google. This means your feeds would be associated with your Google account and you could <span>login</span> with the same <span>username</span>/password as you use to get into Gmail or Google Docs. </span></p> <p><span>I signed in last night for the first time in a while and was prompted with a request to go ahead and perform the migration. I didn't see any downside so I went ahead and clicked Yes. The next screen informed me this would take a few minutes and that I would receive an email when it was finished. Sure enough, about five minutes later I got the email. I signed back intoFeedburner with my Google account info and everything looked like it was moved successfully. I had roughly the same number of subscribers and all my settings were the same. The only noticeable difference was my account name changed to my Google <span>username</span>. </span></p> <p><span>Pretty cool, everything seemed to be <span>ok</span> - not that I expected anything different from Google. However, I decided to check my RSS Reader before heading off to bed and discovered that every single one of my articles was there waiting for me (I subscribe to my own feed just to make sure that it's working properly). How could this be? Would everyone get all my articles in their reader again like it was brand new? Sure enough, some sites whichaggregate my feed into a super-feed were also showing all my of articles. </span></p> <p>So to everyone who got ~34 new items in their feed because of me - Sorry. I'm not sure if this is my fault or what happened but I just wanted to forwarn everyone before they upgrade. </p> 2/3/2009 9:00am PHP Data Types - Octal Notation http://www.mikebernat.com/blog/PHP_Data_Types_-_Octal_Notation <p>I just ran into an interesting question while studying for the Zend certification, and I thought I would share because I was very confused.</p> <p>What is the output of the following:</p> <p><code><span style="color: #000000;"> <span style="color: #0000bb;">&lt;?php<br />$a&nbsp;</span><span style="color: #007700;">=&nbsp;</span><span style="color: #0000bb;">010</span><span style="color: #007700;">;<br /></span><span style="color: #0000bb;">$b&nbsp;</span><span style="color: #007700;">=&nbsp;</span><span style="color: #0000bb;">0xA</span><span style="color: #007700;">;<br /></span><span style="color: #0000bb;">$c&nbsp;</span><span style="color: #007700;">=&nbsp;</span><span style="color: #0000bb;">2</span><span style="color: #007700;">;<br /><br />print&nbsp;</span><span style="color: #0000bb;">$a&nbsp;</span><span style="color: #007700;">+&nbsp;</span><span style="color: #0000bb;">$b&nbsp;</span><span style="color: #007700;">+&nbsp;</span><span style="color: #0000bb;">$c</span><span style="color: #007700;">;<br /></span><span style="color: #0000bb;">?&gt;</span> </span></code></p> 2/1/2009 2:30pm Design Patterns - An Introduction http://www.mikebernat.com/blog/Design_Patterns_-_An_Introduction <p>Over the next couple weeks I'm going to be writing a series on programming design patterns and their applications. I plan to cover the popular patterns as well as the lesser-known, yet still insanely useful, ones too. This first article will go over the background and basics of a design pattern - What they are, why you should care, and how to implement one into your application.&nbsp; </p> 1/27/2009 9:00am Design Patterns - The Singleton http://www.mikebernat.com/blog/Design_Patterns_-_The_Singleton <p>Often one of the first patterns that young developers encounter, the singleton solves a very sloppy, dangerous, and nightmarish practice known as global variables. There are components in nearly every application that need to be accessed everywhere. Configuration variables are a perfect example of this. The younger developers might be tempted to declare a debug variable as global, and just access it where he/she pleases. You will learn later on in the project that this makes maintaining the application very frustrating.</p> 1/27/2009 9:00am Code Refactoring - Freaking Awesome http://www.mikebernat.com/blog/Code_Refactoring_-_Freaking_Awesome <p>We have all gone back and looked at code we wrote in the past and thought "Wow, this is ugly.", or "wtf was I thinking?", or even "I wrote this yesterday, and I have no idea what it does." Refactoring is the process of going back over already-working code and cleaning it up for the sole purpose of understandability, maintainability, and preserving your self-worth if anyone else were to take a peak. No one likes to be humiliated by their own code.</p> 1/2/2009 12:00pm CakePHP - Web Test Cases with SimpleTest http://www.mikebernat.com/blog/CakePHP_-_Web_Test_Cases_with_SimpleTest <p><img style="border: 1px solid black; background: #ffffff none repeat scroll 0% 0%; float: right; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial;" src="http://www.mikebernat.com/images/cake/cake-logo.jpg" border="0" alt="CakePHP" width="100" height="104" />I have fallen in love with CakePHP's integration of the SimpleTest libraries. With the type of work that I normally do, unit-testing is hard to utilize successfully. That is to say, most of the applications I work on have very straight-forward components and not a lot of complex functions/methods. I would only be testing whether or not they worked at all, rather than if they worked in a wide-array of situations. </p> <p>For example, unit-testing a simple news list and detail page is probably overkill. Sure, you can test your classes by simple instantiating them but that only goes so far. My new method involves using SimpleTest's Scriptable Browser to actually crawl webpages and ensure that the proper data is being displayed. That way, I can catch all my php errors, including notices and warnings, insure that the proper headers are being sent, and assert that certain text is appearing on the page. Unit-testing will rarely catch a poorly coded method that throws a PHP notice whereas the Scriptable Browser will.<img style="border: 1px solid black; background: #ffffff none repeat scroll 0% 0%; float: right; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial;" src="http://www.mikebernat.com/images/simpletest-logo.png" border="0" alt="SimpleTest" width="150" height="57" /></p> <p>&nbsp;</p> 12/10/2008 12:00pm CakePHP - Changing the Default Value of a Date-Time Input http://www.mikebernat.com/blog/CakePHP_-_Changing_the_Default_Value_of_a_Date-Time_Input <p>Automagically generated date/time input fields normally default to the current date and time. For a couple of reasons, I had to change this to another default value. For example's sake, let's say I needed a time field to always select 1:30 pm in an add action.</p> <p>Run of the mill example:</p> <p><code><span style="color: #000000;"> <span style="color: #0000bb;">&lt;?php<br />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #007700;">echo&nbsp;</span><span style="color: #0000bb;">$form</span><span style="color: #007700;">-&gt;</span><span style="color: #0000bb;">input</span><span style="color: #007700;">(</span><span style="color: #0000bb;">'start_dt</span><span style="color: #007700;">');<br /></span><span style="color: #0000bb;">?&gt;</span></span></code></p> <p>This will output 3 select boxes; one for hours, minutes, and the merdian (am/pm) with the current time pre-selected. So if it was 3:04 pm, that would be selected.</p> <p>So lets change this so that 1:30 pm is always pre-selected:</p> <p><code><span style="color: #000000;"> <span style="color: #0000bb;">&lt;?php<br />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #007700;">echo&nbsp;</span><span style="color: #0000bb;">$form</span><span style="color: #007700;">-&gt;</span><span style="color: #0000bb;">input</span><span style="color: #007700;">(</span><span style="color: #0000bb;">'start_dt</span><span style="color: #007700;">',&nbsp;array(</span><span style="color: #0000bb;">'selected' </span><span style="color: #007700;">=&gt;&nbsp;array(</span><span style="color: #0000bb;">'hour' </span><span style="color: #007700;">=&gt; </span><span style="color: #0000bb;">'1</span><span style="color: #007700;">', <br /> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp; &nbsp; &nbsp; </span><span style="color: #0000bb;">'minute' </span><span style="color: #007700;">=&gt; </span><span style="color: #0000bb;">'30'</span><span style="color: #007700;">, <br /> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp; &nbsp; &nbsp; </span><span style="color: #0000bb;">'meridian' </span><span style="color: #007700;">=&gt; </span><span style="color: #0000bb;">'pm'</span><span style="color: #007700;">)<br /> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; )<br /> &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; );<br /></span><span style="color: #0000bb;">?&gt;</span></span></code></p> <p>That's all there is to it! Cake's automagic owns. Hope this helps someone else :)</p> 12/8/2008 11:30am MVC - Fat Models and Skinny Controllers http://www.mikebernat.com/blog/MVC_-_Fat_Models_and_Skinny_Controllers_ <p><img style="border: 1px solid black; background: #ffffff none repeat scroll 0% 0%; float: right; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial;" src="http://www.mikebernat.com/images/cake/cake-logo.jpg" border="0" alt="CakePHP" width="100" height="104" /><span>I've been doing a lot of work with CakePHP lately and it has been amazingly satisfying developing in a framework that encourages great coding practices. More on CakePHP, specifically, later. Right now, I'd like to present some things I've learned about the architecture that CakePHP is built on. I'm talking about the Model-View-Controller (MVC) architecture of course. </span> </p> <p><span>I'm hoping most of you reading know already know a thing or two about MVC but if you don't, here is a quick overview from wikipedia.</span></p> <blockquote><strong>Model-view-controller</strong> (<strong>MVC</strong>) is an <a href="http://en.wikipedia.org/wiki/Architectural_pattern_%28computer_science%29" title="Architectural pattern (computer science)">architectural pattern</a> used in <a href="http://en.wikipedia.org/wiki/Software_engineering" title="Software engineering">software engineering</a>. Successful use of the pattern isolates <a href="http://en.wikipedia.org/wiki/Business_logic" title="Business logic">business logic</a> from <a href="http://en.wikipedia.org/wiki/User_interface" title="User interface">user interface</a> considerations, resulting in an application where it is easier to modify either the visual appearance of the application or the underlying business rules without affecting the other. In MVC, the <em>model</em> represents the information (the data) of the application and the business rules used to manipulate the data; the <em>view</em><span> corresponds to elements of the user interface such as text, <span>checkbox</span> items, and so forth; and the </span><em>controller</em> manages details involving the communication to the model of user actions such as keystrokes and <a href="http://en.wikipedia.org/wiki/Mouse_%28computing%29" title="Mouse (computing)">mouse</a> movements.</blockquote> 12/5/2008 6:00pm My PHP Best Practices http://www.mikebernat.com/blog/My_PHP_Best_Practices <p><img style="float: right; padding 3px; border: 1px solid #333; background: #fff;" src="http://www.mikebernat.com/images/practice/keyboard.jpg" border="0" alt="Keyboard" width="250" height="158" />PHP's greatest strength is also its greatest weakness. Flexibility. There are an infinite number of ways to perform the same task which PHP will happily do without so much as a peep as to how poor the code really is. Sadly, most developers endure a trial by fire where they only learn from their mistakes after it's too late. </p> <p>I suggest a more retro-active apprach. Studying, surrounding, and forcing yourself to abide by best-practice coding standards will yield surprising results in your applications despite the fact that it may seem like more work than it's worth. </p> <p>I've come up with a list of things that I feel are most important to me when it comes to coding. So, without further adieu:</p> 10/7/2008 12:00pm Things I Hate - People Who Do-Not Know How to Report Bugs http://www.mikebernat.com/blog/Things_I_Hate_-_People_Who_Do-Not_Know_How_to_Report_Bugs <p><img style="float: right; padding 3px; border: 1px solid #333; background: #fff;" src="http://www.mikebernat.com/images/confused-computer-user.jpg" border="0" alt="Bugs" width="150" height="100" />Bugs are an inevitable part of any development project that most people loath or at least generally dislike. If you take the time to examine this phase of a project you will find that it's not the bugs that really irk you, but the way they are presented, described, and handled. </p> <p><span><span>Ok</span>, so maybe bugs are not the worst part about my job but they can be very effective at frustrating the hell out of me. After you get over the fact that you are not the </span><a href="http://mikebernat.com/blog/Egoless_Programming_-_Developing_Without_the_Attitude">world's greatest programmer and are indeed as fallible as the rest of us</a>, you can begin to look at bug reports as an opportunity to better yourself. Learning from your mistakes is a huge part of the job and can be extremely beneficial. However, no matter how vetted any particular programmer may be, most will cringe when they see a bug drop into their inbox. </p> 10/1/2008 1:00pm Installing Bad Behavior Generic - Anti-Spam Solution http://www.mikebernat.com/blog/Installing_Bad_Behavior_Generic_-_Anti-Spam_Solution <p><span>Site spam sucks, no doubt about it. I was getting tired of fighting it manually in hand-to-hand combat and decided to get some help. I'd heard about different techniques for thwarting comment, and other types of form, spam but none of them seemed to make a big enough dent in the problem for my liking. That is, until I tried </span><a href="http://www.bad-behavior.ioerror.us/">Bad Behavior</a>. </p> 7/28/2008 12:00pm Egoless Programming - Developing Without the Attitude http://www.mikebernat.com/blog/Egoless_Programming_-_Developing_Without_the_Attitude <p>One of the most common threads that all programmers share is that of an ego. Some are much worse than others and some have found a way to control or manipulate their ego into a great benefit. Beyond skill-sets and other programming-specific talents I believe the greatest room for personal improvement in programmers as a whole is that of the ego.</p> <p>A quote by <a href="http://www.amazon.com/exec/obidos/search-handle-url?_encoding=UTF8&amp;search-type=ss&amp;index=books&amp;field-author=Gerald%20M.%20Weinberg"><span><span>GeraldWeinberg</span></span></a> from <a href="http://www.amazon.com/exec/obidos/ISBN=0932633420/portlandpatternrA/">The Psychology Of Computer Programming</a>.</p> <blockquote>The idea is that programmers must fight the natural tendency to treat their programs as part of themselves, and therefore to reject all criticism. Rather, they should do their best to treat their designs &amp; implementations as objects independent of themselves, and to view criticism dispassionately on its merits. It's a spiritual discipline that we all fall short of, but that's worth attempting.</blockquote> 7/15/2008 12:00am Installing Xdebug - Best Decision You Will Ever Make http://www.mikebernat.com/blog/Installing_Xdebug_-_Best_Decision_You_Will_Ever_Make <p><img style="float: right; padding 3px; border: 1px solid #333; background: #fff;" src="http://www.mikebernat.com/images/Xdebug/xdebug.png" border="0" alt="xdebug" width="130" height="75" />I finally got around to installing xdebug on my development environment and have decided it is the best thing since sliced bread.Installation was a breeze and the information it provides when something has gone wrong is incredibly helpful during debugging. What I didn't know, and hope to help others by documenting it here, was the amount of configuration options Xdebug has. The base install has some irritating limitations that are easily addressed with a few simple lines in the php.ini file. </p> 7/1/2008 9:00am PHP - Opening and Saving Files over FTP http://www.mikebernat.com/blog/PHP_-_Opening_and_Saving_Files_over_FTP <p><span>PHP makes file system manipulation easy with its variety of built-in functions. One thing I always knew, but never got the chance to try, is that many of those same functions worked over FTP instead of the local file system. I finally got my excuse to give it the ole' college try and I found a few things that may help others with the same task.</span></p> 6/25/2008 6:00pm The Ternary Operator http://www.mikebernat.com/blog/The_Ternary_Operator <p><img style="float: right; padding 3px; border: 1px solid #333; background: #fff;" src="http://www.mikebernat.com/images/php_logo.gif" border="0" alt="PHP" width="70" height="36" />Every good programmer should constantly be looking for ways to improve the look and readability of their code. One of my favorite ways to reduce vertical length while maintaining readability is to use the lesser-known ternary comparison operator. </p> <p>The Ternary Operator is unique when it comes to PHP's available comparison options. Not in the sense that it does something that the other operators don't, but that the functionality it offers is not seen anywhere else. </p> <p><code><span style="color: #000000;"> <span style="color: #0000bb;">&lt;?php<br />&nbsp;&nbsp;$myvar&nbsp;</span><span style="color: #007700;">=&nbsp;(</span><span style="color: #0000bb;">$x&nbsp;</span><span style="color: #007700;">==&nbsp;</span><span style="color: #0000bb;">$y</span><span style="color: #007700;">)&nbsp;?&nbsp;</span><span style="color: #0000bb;">TRUE&nbsp;</span><span style="color: #007700;">:&nbsp;</span><span style="color: #0000bb;">FALSE</span><span style="color: #007700;">;<br /></span><span style="color: #0000bb;">?&gt;</span> </span> </code> </p> 6/23/2008 12:00pm Caching PHP Pages with Output Buffering http://www.mikebernat.com/blog/Caching_PHP_Pages_with_Output_Buffering <p><img style="border: 1px solid black; background: #ffffff none repeat scroll 0% 0%; float: right; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial; padding: 3px;" src="http://www.mikebernat.com/images/php_logo.gif" border="0" alt="PHP" width="70" height="36" /><span>Noticing your pages are loading slowly or just don't like using extra <span>cpu</span> cycles when you don't have to? PHP makes caching very easy with their variety of Output Control Functions. In this article I'll go over complete page caching which is the easiest to implement and understand.</span></p> 6/18/2008 12:00pm Setting-Up a Relational Database in MySQL http://www.mikebernat.com/blog/Setting-Up_a_Relational_Database_in_MySQL <p><img style="border: 1px solid black; padding: 3px; background: #fff; float: right;" src="http://www.mikebernat.com/images/mysql_logo.gif" border="0" alt="MySQL" />Relational Database Design is one of the most powerful ways to ensure data integrity and a great way to kick-off any project. Very often the first thing developers do when starting a new project, or stub-project, is to design the database. This way the structure of the application is already in place and we just have to fill in the pieces with some server-side code. I've found when adding relational constraints to your database design you add in a very powerful error reporting tool that will let you know during the development process that you have allowed something to happen that shouldn't have. In this article, I go through, step by step, showing how to set up a simple relational database and discuss the benefits that are enjoyed.</p> 6/17/2008 10:30am Adding Virtual Hosts to Apache & Wampserver http://www.mikebernat.com/blog/Adding_Virtual_Hosts_to_Apache_&_Wampserver <p><img style="float: right;border: 0px" src="http://www.mikebernat.com/images/wampserver.png" border="0" alt="Wamp Server" width="116" height="96" />Being able to develop on my local machine with urls like htto://testsite/index.php has been a godsend. Mostly because I am able to take full advantage of the document root. If I were to develop on something like http://localhost/testsite/index.php I would be extremely limited and forced to used relative urls. In this article I've listed the steps in order to enable this functionality in a wamp server environment.</p> 6/15/2008 9:00am How fast can you spot PHP Bugs? http://www.mikebernat.com/blog/How_fast_can_you_spot_PHP_Bugs? <p><a href="http://www.phpvs.net/2008/06/04/ten-php-best-practices-tips-that-will-get-you-a-job/">Blake</a> over at <a href="http://www.phpvs.net">PHP vs .NET</a> has written up a very nice article to prepare those who are interviewing for a php job soon. He basically gives a bunch of php snippets and asks where the bugs are. The article somewhat morphs into a mish-mash of good-practice/bad-practice comparison and explains why one way is better than the other.</p> <p>From the article: </p> <p>Find the errors in the following code: </p> <p><code><span style="color: #000000;"> <span style="color: #0000bb;">&lt;?php </span><span style="color: #007700;"><br />function&nbsp;</span><span style="color: #0000bb;">baz</span><span style="color: #007700;">(</span><span style="color: #0000bb;">$y&nbsp;$z</span><span style="color: #007700;">)&nbsp;{<br />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000bb;">$x&nbsp;</span><span style="color: #007700;">=&nbsp;new&nbsp;Array();<br />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000bb;">$x</span><span style="color: #007700;">[</span><span style="color: #0000bb;">sales</span><span style="color: #007700;">]&nbsp;&nbsp;=&nbsp;</span><span style="color: #0000bb;">60</span><span style="color: #007700;">;<br />&nbsp;&nbsp;&nbsp;&nbsp;</span><span style="color: #0000bb;">$x</span><span style="color: #007700;">[</span><span style="color: #0000bb;">profit</span><span style="color: #007700;">]&nbsp;=&nbsp;</span><span style="color: #0000bb;">20</span><span style="color: #007700;">:<br /><br />&nbsp;&nbsp;&nbsp;&nbsp;foreach(</span><span style="color: #0000bb;">$x&nbsp;</span><span style="color: #007700;">as&nbsp;</span><span style="color: #0000bb;">$key&nbsp;</span><span style="color: #007700;">=&nbsp;</span><span style="color: #0000bb;">$value</span><span style="color: #007700;">)&nbsp;{<br />&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;echo&nbsp;</span><span style="color: #0000bb;">$key</span><span style="color: #007700;">+</span><span style="color: #dd0000;">"&nbsp;\"+$value+\"&lt;BR&gt;\";<br />&nbsp;&nbsp;&nbsp;&nbsp;}<br />}&nbsp;<br />?&gt; </span></span></code></p> 6/14/2008 10:00pm MySQL - InnoDB vs MyISAM http://www.mikebernat.com/blog/MySQL_-_InnoDB_vs_MyISAM <p>Most people who use MySQL know that MyISAM and InnoDB are the two most-common database engines available with the popular opensource datbase provider. I would be that most of those people don't even take the time to select a storage-engine and just accept the database default. Those of you who are left probably heard from a friend who saw something online that said one of the two is better than the other. Those of you who are left will still probably learn a thing or two here :)</p> <p>&nbsp;<img style="border: 0px;" src="http://www.mikebernat.com/images/mysql-logo.png" border="0" alt="MySQL" width="200" height="103" /></p> 6/14/2008 7:00pm Image Styles Not Working in TinyMCE? http://www.mikebernat.com/blog/Image_Styles_Not_Working_in_TinyMCE? <p><img style="float: right;" src="http://www.mikebernat.com/images/moxie.gif" border="0" alt="TinyMCE" />I had an issue lately where image styles that I inputted through <a href="http://tinymce.moxiecode.com/">TinyMCE</a> weren't working. For example, my images would not align right or left, my borders weren't appearing, and even padding wasn't working. I checked the HTML source and found that no styles at all were making it from the popup Image Dialog to the editor!</p> 6/14/2008 1:00pm Funny Names for ASCII Symbols http://www.mikebernat.com/blog/Funny_Names_for_ASCII_Symbols <p><a href="http://www.codinghorror.com/blog/archives/001133.html">Coding Horror</a><span> has a pretty amusing article on the infinite number of names programmers give common <span>ascii</span> symbols. $, %, &amp;, |, etc are seen across a lot of languages but somehow they have accumulated more names than the entire <span>ascii</span> library combined.</span></p> <p style="text-align: center;"><img src="http://uploads.screenshot-program.com/upl3018220683.png" border="0" alt="ASCII Names" width="550" height="126" /></p> 6/14/2008 10:00am Optimization - PHP Benchmarks http://www.mikebernat.com/blog/Optimization_-_PHP_Benchmarks <p>A lot of the gripes about PHP as a language come down to the fact that there are a million ways to accomplish the same task, but only a couple are truely 'correct' - as in significantly better for one reason or another. Out of all those reasons script efficiency and speed are the driving force behind all experienced programmers.&nbsp; That being said it's hard to know what the right way to do things are. Sure there are 100 ways to do something but all but 2 or 3 of those take an obscene amount of time. Normally, during development, you won't notice long load times because it's not getting hammered by thousands of users requesting the same page. </p> <p><a href="http://www.chrisvincent.com.au/" target="_blank">Chris Vincent </a>has set up <a href="http://www.phpbench.com/" target="_blank">The PHP Benchmark</a> to help visually show how some methods are more effecient than others. </p> <blockquote>PHPBench.com was constructed as a way to open people's eyes to the fact that not every PHP code snippet will run at the same speed. </blockquote> <p>A few highlights:</p> <p class="code"><code><span style="color: #000000;"> <span style="color: #0000bb;">&lt;?php <br /></span><span style="color: #007700;">foreach(</span><span style="color: #0000bb;">$aHash&nbsp;</span><span style="color: #007700;">as&nbsp;</span><span style="color: #0000bb;">$val</span><span style="color: #007700;">);<br /></span><span style="color: #ff8000;">//&nbsp;VS<br /></span><span style="color: #007700;">while(list(,</span><span style="color: #0000bb;">$val</span><span style="color: #007700;">)&nbsp;=&nbsp;</span><span style="color: #0000bb;">each</span><span style="color: #007700;">(</span><span style="color: #0000bb;">$aHash</span><span style="color: #007700;">)); <br /></span><span style="color: #0000bb;">?&gt;</span> </span> </code> </p> <ul> <li>foreach($array as $value) is the fastest way to loop through an array.</li> <li>foreach($array as $key =&gt; $value) is slightly slower by about 10-15% so use it only when necassary.</li> <li>Using while() and for() loops dramatically increases the server load especially when used in conjuction with list() and each().</li> </ul> 6/10/2008 8:00am Making Your Tables Easier on the Eyes http://www.mikebernat.com/blog/Making_Your_Tables_Easier_on_the_Eyes <p><a href="http://www.richardoneill.com.au">Richard O'Neill</a> has written a short article on improving user-interface by polishing-up your grids and tables. By making a few simple modifications your information can be easily read and understood. </p><blockquote><p><em>&quot;It's not hard making interfaces look professional. I've found that some good looking icons and a bit of cell padding makes all the difference.<br />Using the example below, we can apply small changes to the design which will improve usability and make this ugly interface look a lot better.&quot;</em></p></blockquote><p><img src="http://www.richardoneill.com.au/img/articles/emailclient5.jpg" border="0" alt=" Making Your Tables Easier on the Eyes" width="532" height="254" /> </p> 9/11/2007 8:00am Creating a Users Online Script using PHP http://www.mikebernat.com/blog/Creating_a_Users_Online_Script_using_PHP <p>Creating a way to show how many users are currently visiting your website has become a fad amongst webmasters. It's a cool way to show off your skills has a coder and to show your visitors how many other people are looking at the same thing they are. You don't want to miss the bandwagon again do you? This script is also an excuse to brush up on some mildly advanced MySQL queries.</p> 9/10/2007 8:00am Making Magic with .htaccess Files http://www.mikebernat.com/blog/Making_Magic_with_.htaccess_Files <p>.htaccess files are one of the most underused and underrated forms of web development. They are very easily overlooked or dismissed as unimportant by the amateur programmer. The reality of it is that .htaccess has some of the coolest and ridiculously easy features to offer.</p> 9/9/2007 8:00am Creating a Simple Registration Script using PHP http://www.mikebernat.com/blog/Creating_a_Simple_Registration_Script_using_PHP <p>The most useful and almost necessary feature of any interactive website is a registration form. A way to give users access to features while keeping out the riff-raff. While a registration script can be the perfect time for an amateur to grab the bull by the horns it can also leave lots of pitfalls for a more experienced programmer.</p> 9/8/2007 8:00am Creating Static RSS Feeds http://www.mikebernat.com/blog/Creating_Static_RSS_Feeds <p><img style="border: 0pt none; float: right;" src="images/rss.png" border="0" alt="rss" />Providing RSS Feeds for your website is fast becoming a necessity in today's web2.0 world. The amount of surfers taking advantage of everything RSS Feeds has to offer has exploded in recent history, and it's easy to see why. The amount gained from offering a RSS Feed far outweigh the effort needed to create one.</p> 9/7/2007 8:00am Using PayPal in your Site - Easier than you Think http://www.mikebernat.com/blog/Using_PayPal_in_your_Site_-_Easier_than_you_Think <p><img style="float: right; border: 0px;" src="http://www.paypal.com/en_US/i/btn/x-click-but01.gif" border="0" alt="PayPal" width="62" height="31" />Integrating PayPal into your site may seem intimidating to those who have never put together a serious project before. It might seem like everything changes when you start dealing with money. You always hear about someone else who has been scammed or in some kind of nightmare involving some sort of online transaction. When you realize how easy PayPal makes it to utilize their services it really puts any anxiety you have to rest.</p> 9/5/2007 8:00am How to Create a Simple PHP Text Counter http://www.mikebernat.com/blog/How_to_Create_a_Simple_PHP_Text_Counter <p>After learning the basics of PHP's basic file system functions, the first thing you'll want to do is put it to use. One of the easiest and flashiest things you can create is a page counting script. I'll show you how to create a page hit script that is easy to create and even easier to implement.</p> 9/4/2007 8:00am PHP Cookies vs Sessions - The Breakdown http://www.mikebernat.com/blog/PHP_Cookies_vs_Sessions_-_The_Breakdown <p>Knowing the basics of cookies and sessions is essential to any successful PHP programmer. It is useful to store pieces information on the users computer for later use. Things like when they laste visited, language of choice, age, etc. Cookies and Sessions are the perfect solution to our needs.</p> <table border="0" cellspacing="0" cellpadding="1"> <tbody> <tr> <td>&nbsp;</td> <td style="background-color: #46647c; border: 1px solid"><strong>Browser needs Cookies Enabled? </strong></td> <td style="background-color: #46647c; border: 1px solid"><strong>Can User Edit Information?</strong></td> <td style="background-color: #46647c; border: 1px solid"> <p><strong>Information Lasts Between Browser Sessions?</strong></p> <p><strong>(Leaving site and coming back)&nbsp;</strong></p> </td> <td style="background-color: #46647c; border: 1px solid"><strong>Information Location&nbsp;</strong></td> </tr> <tr> <td style="background-color: #46647c; border: 1px solid"><strong>Cookies</strong> <br /></td> <td style="background-color: #b3babf; border: 1px solid">&nbsp;Yes</td> <td style="background-color: #b3babf; border: 1px solid">&nbsp;Yes, easily<br /></td> <td style="background-color: #b3babf; border: 1px solid">&nbsp;Yes</td> <td style="background-color: #b3babf; border: 1px solid">&nbsp;User's Browser<br /></td> </tr> <tr> <td style="background-color: #46647c; border: 1px solid"><strong>Sessions</strong><br /></td> <td style="background-color: #c0c0c0; border: 1px solid">&nbsp;No<br /></td> <td style="background-color: #c0c0c0; border: 1px solid">&nbsp;No* </td> <td style="background-color: #c0c0c0; border: 1px solid">&nbsp;No</td> <td style="background-color: #c0c0c0; border: 1px solid">&nbsp;Server, except for session ID<br /></td> </tr> </tbody> </table> 9/3/2007 8:00am Using PHP to Access Files - The Basics http://www.mikebernat.com/blog/Using_PHP_to_Access_Files_-_The_Basics <p>The first thing I wanted to know after learning the basics of PHP was how to store my data on a more permanent basis. PHP is all well and good but without the ability to store data between browser sessions it has limited functionality. After learning how to store and retrieve data, your PHP scripts really come to life.</p> 9/2/2007 8:00am Making your MySQL Tables More Effecient by Using Correct Fieldtypes http://www.mikebernat.com/blog/Making_your_MySQL_Tables_More_Effecient_by_Using_Correct_Fieldtypes <p><span style="font-size: x-small;">One of the biggest mistakes of today's fledgling MySQL programmers is their field type definitions, also known as data type or column type. Many are too quick to set up their tables, flying through the different options without giving it much thought. The time you spend setting up your tables will save you from many headaches later on down the road.</span></p> 9/1/2007 8:00am