1. Go to this page and download the library: Download spotweb/fts_parser library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
spotweb / fts_parser example snippets
// Get input into $text via form post or command line...
$text = '("black and white" or "cut \'n dry") and not (gray | grey)';
$o_parse = new parse_model();
$o_parse->debug = true;
$o_parse->use_prepared_sql = true;
$o_db = new PDO('pgsql:host=localhost;dbname=mydb', 'user', 'pass');
if ( $text != '' )
{
if ( $o_parse->parse($text, 'fulltext') == false )
echo "Message to user: [$o_parse->error_msg]\n\n";
else
{
$query = "SELECT * FROM some_table WHERE ";
// The tsearch clause does NOT come back escaped.
if ( $o_parse->tsearch != '' )
$query .= "fulltext @@ to_tsquery(" . $o_db->quote($o_parse->tsearch) . ") ";
// When $o_parse->use_prepared_sql is true, the values for the ILIKE are NOT
// escaped, otherwise the clause that comes back will have single quotes
// escaped with the character passed to the parse() function (which uses a
// single quote as the default). Because of how the ILIKE statement has to
// be built, the escaping must be performed at parse time.
if ( $o_parse->ilike != '' )
$query .= ($o_parse->tsearch != '' ? "AND " : '') . "($o_parse->ilike)";
echo "\nSample Query: $query\n\n";
$o_q = $o_db->prepare($query);
// Bind the ILIKE clause variables because $o_parse->use_prepared_sql was
// set to true. PDO will ensure the values are escaped properly (one of
// the many reasons for using PDO).
foreach ( $o_parse->db_ilike_data as $varname => $value )
$o_q->bindValue($varname, $value);
$o_q->execute();
}
}
$o_parse = new parse_model();
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.