00001 <?php
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037 include_once( 'lib/ezdb/classes/ezdb.php' );
00038
00039 class eZSearchLog
00040 {
00041
00042
00043 function eZSearchLog()
00044 {
00045
00046 }
00047
00048
00049
00050
00051 function addPhrase( $phrase, $returnCount )
00052 {
00053 $db =& eZDB::instance();
00054 $db->begin();
00055
00056 include_once( 'lib/ezi18n/classes/ezchartransform.php' );
00057 $trans =& eZCharTransform::instance();
00058 $phrase = $trans->transformByGroup( trim( $phrase ), 'lowercase' );
00059
00060 $phrase = $db->escapeString( $phrase );
00061
00062
00063 $phraseRes = $db->arrayQuery( "SELECT id FROM ezsearch_search_phrase WHERE phrase='$phrase'" );
00064
00065 if ( count( $phraseRes ) == 1 )
00066 {
00067 $phraseID = $phraseRes[0]['id'];
00068 $db->query( "UPDATE ezsearch_search_phrase
00069 SET phrase_count = phrase_count + 1,
00070 result_count = result_count + $returnCount
00071 WHERE id = $phraseID" );
00072 }
00073 else
00074 {
00075 $db->query( "INSERT INTO
00076 ezsearch_search_phrase ( phrase, phrase_count, result_count )
00077 VALUES ( '$phrase', 1, $returnCount )" );
00078
00079
00080 $phraseID = $db->lastSerialID( 'ezsearch_search_phrase', 'id' );
00081 }
00082
00083
00084
00085
00086 $time = mktime();
00087
00088 $db->query( "INSERT INTO
00089 ezsearch_return_count ( phrase_id, count, time )
00090 VALUES ( '$phraseID', '$returnCount', '$time' )" );
00091
00092
00093 $db->commit();
00094 }
00095
00096
00097
00098
00099 function &mostFrequentPhraseArray( $parameters = array( ) )
00100 {
00101 $db =& eZDB::instance();
00102
00103 $query = 'SELECT phrase_count, result_count / phrase_count AS result_count, id, phrase
00104 FROM ezsearch_search_phrase
00105 ORDER BY phrase_count DESC';
00106
00107 $phraseArray = $db->arrayQuery( $query, $parameters );
00108
00109 return $phraseArray;
00110 }
00111
00112
00113
00114
00115
00116 function removeStatistics()
00117 {
00118 $db =& eZDB::instance();
00119 $query = "DELETE FROM ezsearch_search_phrase";
00120 $db->query( $query );
00121
00122 $query = "DELETE FROM ezsearch_return_count";
00123 $db->query( $query );
00124 }
00125 }
00126
00127 ?>