sql >> Database >  >> RDS >> Mysql

Hoe het fragment genereren zoals dat door Google is gegenereerd met PHP en MySQL?

De deceze-functie enigszins aangepast om meerdere frases mogelijk te maken. bijv. uw zin kan "testa testb" zijn en als het testa niet vindt, gaat het naar testb.

function excerpt($text, $phrase, $radius = 100, $ending = "...") { 


         $phraseLen = strlen($phrase); 
       if ($radius < $phraseLen) { 
             $radius = $phraseLen; 
         } 

         $phrases = explode (' ',$phrase);

         foreach ($phrases as $phrase) {
             $pos = strpos(strtolower($text), strtolower($phrase)); 
             if ($pos > -1) break;
         }

         $startPos = 0; 
         if ($pos > $radius) { 
             $startPos = $pos - $radius; 
         } 

         $textLen = strlen($text); 

         $endPos = $pos + $phraseLen + $radius; 
         if ($endPos >= $textLen) { 
             $endPos = $textLen; 
         } 

         $excerpt = substr($text, $startPos, $endPos - $startPos); 
         if ($startPos != 0) { 
             $excerpt = substr_replace($excerpt, $ending, 0, $phraseLen); 
         } 

         if ($endPos != $textLen) { 
             $excerpt = substr_replace($excerpt, $ending, -$phraseLen); 
         } 

         return $excerpt; 
   } 

Markeerfunctie

function highlight($c,$q){ 
$q=explode(' ',str_replace(array('','\\','+','*','?','[','^',']','$','(',')','{','}','=','!','<','>','|',':','#','-','_'),'',$q));
for($i=0;$i<sizeOf($q);$i++) 
    $c=preg_replace("/($q[$i])(?![^<]*>)/i","<span class=\"highlight\">\${1}</span>",$c);
return $c;}


  1. Cumulatief totaal berekenen in MySQL

  2. Genereer SQL Create-scripts voor bestaande tabellen met Query

  3. hoe gebruik je een like met een join in sql?

  4. SQLAlchemy DELETE Fout veroorzaakt door een zowel luie belasting als een dynamische versie van dezelfde relatie