I'm using perl to search a database. It works fine with "and" and "or" searches. I'm trying to get it to work like Google in that if I put quotes around the string, the search has to return that exact string. I'm currently using the following:
$searchtextterms = $in{'searchtextterms'}; $origterms = $searchtextterms; $escterms = $searchtextterms; $escterms =~ s/ /%20/g; $searchtextterms =~ s/\'/\\'/g; $andor = $in{'andor'}; $andor = "AND" if ($andor eq ""); # break searchtextterms on white space to do AND or OR strings @words = split (/ /, $searchtextterms); $num_words = @words; $terms_string = "(title Like '%$words[0]%' OR description Like '%$word +s[0]%' OR organization Like '%$words[0]%' OR type Like '%$words[0]%') +"; for ($n=1; $n<=$num_words-1; $n++) { $terms_string = $terms_string . " $andor (title Like '%$wo +rds[0]%' OR description Like '%$words[0]%' OR organization Like '%$wo +rds[0]%' OR type Like '%$words%')" if ($words[$n] ne ""); } $SQL = "SELECT num FROM database WHERE ($terms_string)";
I just need to know how to do an if $searchtextterms are between quotes, do a query on the whole phrase. Thanks.

In reply to Help with search query by htmanning

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.