Skip to content

peterujah/php-search-controller

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PHPSearchController

PHPSearchController is a simple PHP class to search MySQL database, it can build SQL queries to perform MySQL database searches by taking parameters that define database table fields and field values to search.

The class generates SQL conditions used to build SQL queries to perform database searches for records that match the criteria based on the table fields and field values defined by the parameters, It then combines several conditions using SQL operators such as AND, OR, NAND, LIKE NOR & FIND_IN_SET and return the appropriate queries for the search.

Installation

Installation is super-easy via Composer:

composer require peterujah/php-search-controller

Usages

Initialize the class with your preferred search method the default method is SearchController::OR.

use Peterujah\NanoBlock\SearchController;
$search = new SearchController();

Set your preferred search operator the default is SearchController::END_WITH_QUERY.

$search->setOperators(SearchController::HAVE_ANY_QUERY);

To perform a database search, you can just build your search query like the one below.

$searchQuery = "PHP Code";
$search->setQuery($searchQuery)->split();
$search->setParameter(array(
    'code_title', 
    'code_description', 
    'code_info'
));
//var_export($search->getQuery());

To search by tag using MySQL FIND_IN_SET, build a query like the example below.

$searchQuery = "PHP Code";
$search->setQuery($searchQuery)->split();
$search->setTags("code_tags");
//var_export($search->getQuery());

Set the initial query and pass the search query to your MySQL connection

$search->setIniQuery("SELECT * FROM code WHERE id = 1323");
$db->conn()->prepare($search->getQuery());
$db->conn()->execute();		
$result = $db->conn()->getAll();
$db->conn()->free();

OR build it with other sql queries like the below in your MySQL connection

$db->conn()->prepare("
    SELECT * FROM code 
    {$search->getQuery()}
    AND id = 1323
");
$db->conn()->execute();		
$result = $db->conn()->getAll();
$db->conn()->free();

Other Methods

Returns the computed sql search queries by checking if the initial query was specified or not to determine which start clause is needed.

$search->getQuery()

Set your search keyword

$search->setQuery("Foo Bar")

Split search keyword Foo Bar into Foo, Bar as separate search terms

$search->split()

Mapping your database column keys to perform a search on

$search->setParameter(array)

Set the initial SQL query before appending the search after your query string

$search->setIniQuery('SELECT * FROM ...')

Reference

Specify search operator $search->setOperators(SearchController::HAVE_ANY_QUERY)

Search Operators Description
START_WITH_QUERY Finds any values that start with "query"
END_WITH_QUERY Finds any values that end with "query"
HAVE_ANY_QUERY Finds any values that have "query" in any position
HAVE_SECOND_QUERY Finds any values that have "query" in the second position
START_WITH_QUERY_2LENGTH Finds any values that start with "query" and are at least 2 characters in length
START_WITH_QUERY_3LENGTH Finds any values that start with "query" and are at least 3 characters in length
START_END_WITH_QUERY Finds any values that start with "query" and ends with "query"

Initialize search class with a method new SearchController(SearchController::OR)

Search Methods Description
OR Retrieve result with any one of search query
AND Retrieve result with the exact of search quer
NAND Retrieve result without the exact search query
NOR Retrieve result without any on of the search query