这篇文章给大家介绍使用thinkPHP怎么实现一个多表查询和分页功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
// 异步请求试卷夹下某一个试卷夹的列表
public function ajaxLists() {
extract($_GET);
$page = intval($_GET['p']);
$prefix = C('DB_PREFIX');
$collect = $prefix . 'collect';
$resource = $prefix . 'resource';
if ($keyword) {
$arr = preg_split('/ /', $keyword);
// 搜索标签
foreach ($arr as $value) {
$id = A('Home/Papers')->trunWordToId(array($value));
if ($id) {
$where['resource.rta_id'][] = array('LIKE', '%,' . $id . ',%');
}
$where['resource.re_title'][] = array('LIKE', '%' . $value . '%');
}
if ($where['resource.rta_id']) {
$where['resource.rta_id'][] = 'AND';
}
if ($where['resource.re_title']) {
$where['resource.re_title'][] = 'OR';
}
if ($where['resource.re_title'] && $where['resource.rta_id']) {
$where['_logic'] = 'OR';
}
}
if ($where) {
$map['_complex'] = $where;
}
$map['collect.a_id'] = $this->authInfo['a_id'];
$map['_string'] = 'collect.col_object_id = resource.re_id';
// 总数
$count = M()->table("$collect collect, $resource resource")->where($map)->count();
// 总页数
$regNum = ceil($count/6);
// 验证当前请求页码是否大于总页数
$page = $page > $regNum ? $regNum : $page;
// 引入ajax分页库
import("@.ORG.Util.AjaxPage");
$Page = new AjaxPage($count, 6);
$list['page'] = trim($Page->show());
$list['list'] = M()->table("$collect collect, $resource resource")->where($map)->order('col_id DESC')->limit($Page->firstRow . ',' . $Page->listRows)->field('collect.col_id,collect.col_object_id,resource.re_id,resource.re_title,resource.re_created,resource.re_collect_count,resource.re_score_count,resource.re_score_num,resource.rta_id')->select();
// 获取试卷的标签
$wheree['rta_id'] = array('IN', trim(str_replace(',,', ',', implode('', getValueByField($list['list'], 'rta_id'))), ','));
$tag = setArrayByField(M('ResourceTag')->where($wheree)->field('rta_id,rta_title')->select(), 'rta_id');
// 把标签和试卷对应
foreach ($list['list'] as $key => &$value) {
$str = '';
foreach ($tag as $k => $v) {
if (strpos($value['rta_id'], ',' . $k . ',') !== FALSE) {
$str .= ' | ' . $v['rta_title'];
}
$value['rta_title'] = trim($str, ' |');
}
if ($keyword) {
foreach ($arr as $vv) {
if (strpos($value['re_title'], $vv) !== FALSE) {
$value['re_title'] = str_replace($vv, '<font color=\'red\'>' . $vv . '</font>', $value['re_title']);
}
if (strpos($value['rta_title'], $vv) !== FALSE) {
$value['rta_title'] = str_replace($vv, '<font color=\'red\'>' . $vv . '</font>', $value['rta_title']);
}
}
}
$value['re_created'] = date('Y-m-d', $value['re_created']);
}
echo json_encode($list);
}
关于使用thinkPHP怎么实现一个多表查询和分页功能就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。