ILIAS  release_5-0 Revision 5.0.0-1144-gc4397b1f870
ilLikeUserMultiFieldSearch Class Reference
+ Inheritance diagram for ilLikeUserMultiFieldSearch:
+ Collaboration diagram for ilLikeUserMultiFieldSearch:

Public Member Functions

 __construct ($qp_obj)
 Constructor @access public. More...
 
 performSearch ()
 Perform search. More...
 
 setFields ($a_fields)
 
 __createWhereCondition ()
 
- Public Member Functions inherited from ilAbstractSearch
 ilAbstractSearch (&$qp_obj)
 Constructor @access public. More...
 
 setFields ($a_fields)
 Set fields to search. More...
 
 getFields ()
 Get fields to search. More...
 
 setFilter ($a_filter)
 set object type to search in More...
 
 setIdFilter ($a_id_filter)
 Set id filter Filters search by given object id. More...
 
 getIdFilter ()
 Get Id filter. More...
 
 appendToFilter ($a_type)
 Append object type to filter. More...
 
 getFilter ()
 get object type to search in More...
 
 __createLocateString ()
 build locate string in case of AND search More...
 
 __prepareFound (&$row)
 
performSearch ()
 

Additional Inherited Members

- Data Fields inherited from ilAbstractSearch
 $db = null
 
 $query_parser = null
 
 $search_result = null
 
 $object_types
 

Detailed Description

Definition at line 17 of file class.ilLikeUserMultiFieldSearch.php.

Constructor & Destructor Documentation

◆ __construct()

ilLikeUserMultiFieldSearch::__construct (   $qp_obj)

Constructor @access public.

Definition at line 24 of file class.ilLikeUserMultiFieldSearch.php.

25 {
26 parent::__construct($qp_obj);
27 }

Member Function Documentation

◆ __createWhereCondition()

ilLikeUserMultiFieldSearch::__createWhereCondition ( )

Definition at line 69 of file class.ilLikeUserMultiFieldSearch.php.

70 {
71 global $ilDB;
72
73 $fields = $this->getFields();
74 $field = $fields[0];
75
76 $and = " WHERE field_id = ".$ilDB->quote($field, "text")." AND ( ";
77 $counter = 0;
78 foreach($this->query_parser->getQuotedWords() as $word)
79 {
80 if($counter++)
81 {
82 $and .= " OR ";
83 }
84
85 if(strpos($word,'^') === 0)
86 {
87 $and .= $ilDB->like("value", "text", substr($word,1)."%");
88 }
89 else
90 {
91 $and .= $ilDB->like("value", "text", "%".$word."%");
92 }
93 }
94 return $and.") ";
95 }
getFields()
Get fields to search.
global $ilDB

References $ilDB, and ilAbstractSearch\getFields().

Referenced by performSearch().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ performSearch()

ilLikeUserMultiFieldSearch::performSearch ( )

Perform search.

Returns
type

Reimplemented from ilAbstractSearch.

Definition at line 33 of file class.ilLikeUserMultiFieldSearch.php.

34 {
35 $where = $this->__createWhereCondition();
36 $locate = $this->__createLocateString();
37
38 $query = "SELECT usr_id ".
39 $locate.
40 "FROM usr_data_multi ".
41 $where;
42
43 $GLOBALS['ilLog']->write(__METHOD__.': '.$query);
44
45 $res = $this->db->query($query);
46 while($row = $res->fetchRow(DB_FETCHMODE_OBJECT))
47 {
48 $this->search_result->addEntry($row->usr_id,'usr',$this->__prepareFound($row));
49 }
51 }
const DB_FETCHMODE_OBJECT
Definition: class.ilDB.php:11
__createLocateString()
build locate string in case of AND search
$GLOBALS['ct_recipient']

References $GLOBALS, $query, $res, $row, ilAbstractSearch\$search_result, ilAbstractSearch\__createLocateString(), __createWhereCondition(), and DB_FETCHMODE_OBJECT.

+ Here is the call graph for this function:

◆ setFields()

ilLikeUserMultiFieldSearch::setFields (   $a_fields)
Parameters

return

Reimplemented from ilAbstractSearch.

Definition at line 59 of file class.ilLikeUserMultiFieldSearch.php.

60 {
61 foreach($a_fields as $field)
62 {
63 $fields[] = $field;
64 }
65 parent::setFields($fields ? $fields : array());
66 }

The documentation for this class was generated from the following file: