mysql简单的函数实例教程_一个简单的 MySQL 搜索函数使用实例

怎么才能更好的学习MySQL,下面小编带你们了结一个简单的 MySQL 搜索函数。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('[[:<:>:]]', '', $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;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值