添加代码
首页 > MySQL > 片段代码

发布者

Jeff 发于2010/10/27 17h

查看次数:64998

谁收藏了?

6人已收藏

MySQL搜索表的通用函数

不用写长长的mysql语句,直接用这个函数就可以方便的实现搜索,调用函数在函数中填上要搜索的表名,字段名,关键词,条件(or and),排序方法等,例子如下:
mysqlsearch('items', 'title tags', isset($GET['q'])?$GET['q']:'', Array('columns'=>'*', 'method'=>'OR', 'extrasql'=>'AND active = "true" ORDER BY id DESC'));
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
if (!function_exists('mysql_search')) {
 
   function mysql_search($table, $columns, $query = '', $options = Array()) {
 
      if (empty($query)) { return Array(); }
 
      $sql_query = Array();
 
      $options['columns'] = isset($options['columns'])?$options['columns']:'*';
      $options['method'] = isset($options['method'])?$options['method']:'OR';
      $options['extra_sql'] = isset($options['extra_sql'])?$options['extra_sql']:'';
 
      $query = ereg_replace('[[:<:]](and|or|the)[[:>:]]', '', $query);
      $query = ereg_replace(' +', ' ', trim(stripslashes($query)));
 
      $pattern = '/([[:alpha:]:]+)([[:alpha:] ]+)[[:alpha:]]?+[ ]?/i';
 
      $regs = Array();
 
      preg_match_all($pattern, $query, $regs);
 
      $query = $regs[0];
 
      while (list($key, $value) = @each($query)) {
 
         $column = $columns;
         $keywords = urldecode($value);
 
         if (strpos($value, ':')) {
 
            $column = substr($value, 0, strpos($value, ':'));
            $keywords = trim(substr($keywords, strpos($keywords, ':') + 1));
            $keywords = ereg_replace('\'', '', $keywords);
 
         } else { $keywords = ereg_replace(' +', '|', $keywords); }
 
         $column_list = explode(' ', $column);
 
         $sql = Array();
 
         for ($i = 0; $i < count($column_list); $i++) { $sql[] = '' . $column_list[$i] . ' REGEXP "' . $keywords . '"'; }
 
         $query[$key] = Array('orignal'=>$value, 'sql'=>implode(' ' . $options['method'] . ' ', $sql));
 
         $sql_query = array_merge($sql_query, $sql);
         $sql_query = implode(' ' . $options['method'] . ' ', $sql_query);
 
      }
 
      $results = mysql_fetch_results(mysql_query('SELECT ' . $options['columns'] . ' FROM ' . $table . ' WHERE ' . $sql_query . ' ' . $options['extra_sql']));
 
      return $results;
 
   }
 
}

评论

提交成功!

您现面为匿名用户,暂不能发表评论。如想评论则请登录注册