欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

%t WHERE 1 %i 里面的%t和%i,是如何控制的。

程序员文章站 2022-06-09 10:04:50
...
%t WHERE 1 %i 里面的%t和%i,是怎么控制的。。
下面的代码,是怎么实现控制%t和%i输出的结果啊。。?


public function fetch_all_by_search($tableid, $tid = null, $keywords = null, $invisible = null, $fid = null, $authorid = null, $author = null, $starttime = null, $endtime = null, $useip = null, $first = null, $start = null, $limit = null) {
$sql = '';
$sql .= $tid ? ' AND '.DB::field('tid', $tid) : '';
$sql .= $authorid ? ' AND '.DB::field('authorid', $authorid) : '';
$sql .= $invisible !== null ? ' AND '.DB::field('invisible', $invisible) : '';
$sql .= $first !== null ? ' AND '.DB::field('first', $first) : '';
$sql .= $fid ? ' AND '.DB::field('fid', $fid) : '';
$sql .= $author ? ' AND '.DB::field('author', $author) : '';
$sql .= $starttime ? ' AND '.DB::field('dateline', $starttime, '>=') : '';
$sql .= $endtime ? ' AND '.DB::field('dateline', $endtime, ' $sql .= $useip ? ' AND '.DB::field('useip', $useip, 'like') : '';
if(trim($keywords)) {
$sqlkeywords = $or = '';
foreach(explode(',', str_replace(' ', '', $keywords)) as $keyword) {
$keyword = addslashes($keyword);
$sqlkeywords .= " $or message LIKE '%$keyword%'";
$or = 'OR';
}
$sql .= " AND ($sqlkeywords)";
}
if($sql) {
return DB::fetch_all('SELECT * FROM %t WHERE 1 %i ORDER BY dateline DESC %i', array(self::get_tablename($tableid), $sql, DB::limit($start, $limit)));
} else {
return array();
}
}

------解决思路----------------------
那你看看 DB::fetch_all 的定义
%t WHERE 1 %i 里面的%t和%i,是如何控制的。

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

相关文章

相关视频