MySQL
  Home arrow MySQL arrow Page 3 - Building a Search Engine with MySQL an...
Dev Shed Forums 
Administration  
Apache  
BrainDump  
DHTML  
Flash  
Java  
JavaScript  
Multimedia  
MySQL  
Oracle  
Perl  
PHP  
Practices  
Python  
Reviews  
Security  
Style-Sheets  
Web Services  
XML  
Zend  
Zope  
Forums Sitemap 
IBM® developerWorks 
Dedicated Servers 
E-Commerce Hosting 
Linux Web Hosting 
Managed Hosting 
Small Business Hosting 
Download TestComplete 
VPS Hosting 
Weekly Newsletter

 
Developer Updates  
Free Website Content 
 RSS  Articles
 RSS  Forums
 RSS  All Feeds
Write For Us Get Paid 
Request Media Kit
Contact Us 
Site Map 
Privacy Policy 
Support 
 USERNAME
 
 PASSWORD
 
 
  >>> SIGN UP!  
  Lost Password? 
MYSQL

Building a Search Engine with MySQL and PHP 5
By: Alejandro Gervasio
  • Search For More Articles!
  • Disclaimer
  • Author Terms
  • Rating: 4 stars4 stars4 stars4 stars4 stars / 18
    2007-07-31

    Table of Contents:
  • Building a Search Engine with MySQL and PHP 5
  • Creating the front end
  • Performing searches with MySQL and PHP 5
  • Assembling the modules of the MySQL-driven search application

  • Rate this Article: Poor Best 
      ADD THIS ARTICLE TO:
      Del.ici.ous Digg
      Blink Simpy
      Google Spurl
      Y! MyWeb Furl
    Email Me Similar Content When Posted
    Add Developer Shed Article Feed To Your Site
    Email Article To Friend
    Print Version Of Article
    PDF Version Of Article
     
     
     
    ADVERTISEMENT

    TestComplete™ automates software testing for a fraction of what the big guys charge. Easy functional and load testing for all Windows, .NET, Java and Web apps. Download a free trial now.

    Building a Search Engine with MySQL and PHP 5 - Performing searches with MySQL and PHP 5
    (Page 3 of 4 )

    As you might have guessed, developing the business logic that drives this MySQL-based search application is reduced to defining a couple of PHP classes. These classes will be responsible for performing some crucial tasks, such as connecting to MySQL and executing a specific SELECT statement, as well as returning to the browser the corresponding database results in accordance with the search terms entered on the online form that you saw previously.

    To perform all of the aforementioned tasks, below I defined two basic PHP classes. You'll probably find them quite familiar, since I have used them with some of my previous articles on PHP development published here on the prestigious Developer Shed network.

    The classes in question have been wrapped into one single file, called "mysql.php", whose signature looks like this:

    (definition of "mysql.php" file)

    <?php

    // define 'MySQL' class

    class MySQL{

    private $conId;

    private $host;

    private $user;

    private $password;

    private $database;

    private $result;

    const OPTIONS=4;

    public function __construct($options=array()){

    if(count($options)!=self::OPTIONS){

    throw new Exception('Invalid number of connection parameters');

    }

    foreach($options as $parameter=>$value){

    if(!$value){

    throw new Exception('Invalid parameter '.$parameter);

    }

    $this->{$parameter}=$value;

    }

    $this->connectDB();

    }

    // connect to MySQL

    private function connectDB(){

    if(!$this->conId=mysql_connect($this->host,$this->user,$this-
    >password)){

    throw new Exception('Error connecting to the server');

    }

    if(!mysql_select_db($this->database,$this->conId)){

    throw new Exception('Error selecting database');

    }

    }

    // run query

    public function query($query){

    if(!$this->result=mysql_query($query,$this->conId)){

    throw new Exception('Error performing query '.$query);

    }

    return new Result($this,$this->result);

    }

    public function escapeString($value){

    return mysql_escape_string($value);

    }

    }

    // define 'Result' class

    class Result {

    private $mysql;

    private $result;

    public function __construct(&$mysql,$result){

    $this->mysql=&$mysql;

    $this->result=$result;

    }

    // fetch row

    public function fetchRow(){

    return mysql_fetch_assoc($this->result);

    }

    // count rows

    public function countRows(){

    if(!$rows=mysql_num_rows($this->result)){

    return false;

    }

    return $rows;

    }

    // count affected rows

    public function countAffectedRows(){

    if(!$rows=mysql_affected_rows($this->mysql->conId)){

    throw new Exception('Error counting affected rows');

    }

    return $rows;

    }

    // get ID form last-inserted row

    public function getInsertID(){

    if(!$id=mysql_insert_id($this->mysql->conId)){

    throw new Exception('Error getting ID');

    }

    return $id;

    }

    // seek row

    public function seekRow($row=0){

    if(!is_int($row)||$row<0){

    throw new Exception('Invalid result set offset');

    }

    if(!mysql_data_seek($this->result,$row)){

    throw new Exception('Error seeking data');

    }

    }

    }

    ?>

    As illustrated above, the previous PHP file uses a pair of MySQL processing classes to perform a search process against one or more selected databases. Also, you should notice that the versatile and extensible structure offered by the above PHP classes makes it really easy to implement an internal search engine on any existing web site, a feature that speaks for itself about the expandability of this MySQL-based search application.

    So far, so good. At this time you hopefully grasped the business logic that stands behind this search engine, since it only requires a few simple PHP classes to perform the corresponding searches on the MySQL server. So what's the next step? 

    Well, assuming that you may want to see how all the previously defined files can be linked with each other to implement a fully-functional search application, in the following section I'm going to develop an illustrative example to show you how to put this MySQL-based search engine to work quickly.

    To learn how this hands-on example will be developed, please click on the link that appears below and keep reading.

    More MySQL Articles
    More By Alejandro Gervasio


       · In this first oart of the series, the basic structure of this PHP 5-based search...
       · Is there a way to weight the results? For example, if the 'firstname' col is a...
       · Thank you for commenting on my PHP article. Regarding your question, it's possible...
       · Excellent, thank you. (i will probably have some questions for you on that...
       · Again, thank you for your comments.Regards.
       · Again, thank you for your comments.Regards.
       · This system is WAY too complicated. It really doesn't need to be this complex.How...
       · Thank you for commenting on my PHP article. Yes, the code sample you listed...
       · I'm not getting any result out of this code and I don't find the assignment for...
       · Thank you for commenting on my PHP article. Actually, this search engine works just...
       · Thanx I knew what's going on now actually it's my fault cause I made a dump mistake...
       · Thank you for the comments on my PHP article. And I'm glad to know you fixed up the...
       · I have all the code as shown and the MySQL is the right type etc, but when I click...
       · Thank you for commenting on my PHP article. Concerning your question, as I expressed...
       · Thank you for writing this tutorial. I am still learning about classes and don't...
       · very nice articles. simple, effective and extremely useful. it's exactly what our...
     

       

    MYSQL ARTICLES

    - MySQL Table Prefix Changer Tool in PHP
    - Using the SIGNAL Statement for Error Handling
    - Error Handling Examples
    - Error Handling
    - Completing a Search Engine with MySQL and PH...
    - Paginating Result Sets for a Search Engine B...
    - Building a Search Engine with MySQL and PHP 5
    - Using Boolean Operators for Full Text and Bo...
    - PHP, MySQL and the PEAR Database
    - Working with PHP and MySQL
    - Getting PHP to Talk to MySQL
    - Creating an RSS Reader: the Reader
    - MySQL Security Overview
    - Creating the Admin Script for a PHP/MySQL Bl...
    - Creating the Blog Script for a PHP/MySQL Blo...




    © 2003-2008 by Developer Shed. All rights reserved. DS Cluster 1 hosted by Hostway