ci框架使用FIND_IN_SET

本文介绍了一段控制器代码,展示了如何使用SQL LIKE操作筛选Python主题的课程,同时剖析了数据模型中get_list_like方法的细节。

控制器代码:
$where=Array(
    status=>1,
    xingzhi=>1,
    ctype=>3,
    zhuanye=>3,
    ruanjian=>3
)
$likeWhere['mingcheng'] = "python";
$query = $this->CourseModel->get_list_like($where,array("start"=>0,"pagesize"=>20),'pid asc,time desc','*',$likeWhere);

 

数据模型方法:
public function get_list_like($where = array(), $page_info = array(), $orderby = 'id DESC', $field = '*',$likeWhere = array())
{
    $where = empty($where) ? array() : $where;
    $this->set_limit($page_info);
    if(isset($where['ruanjian']) && !empty($where['ruanjian'])){
        $this->db->where("FIND_IN_SET($where[ruanjian],ruanjian) !=", 0);
        unset($where['ruanjian']);
    }
    $this->db->select($field)->from($this->tablename)->where($where);
    if(isset($likeWhere['mingcheng']) && !empty($likeWhere['mingcheng'])){
        $this->db->like('mingcheng', $likeWhere['mingcheng'], 'both');
    }
    $data =   $this->db->order_by($orderby)->get()->result_array();
    echo $this->db->last_query();//打印sql语句
    return $this->return_array($data);
}


sql结果:
SELECT `id`, `mingcheng`, `zhouqi`, `xb_jiage`, `yc_jiage`, `ke_pic`, `cont`, `content`, `time`, `zhuanye`, `dengji`, `ruanjian` FROM `pre_cda_kecheng_fabu` WHERE FIND_IN_SET(4,ruanjian) != 0 AND `status` = 1 AND `xingzhi` = 1 AND `ctype` = '3' AND `zhuanye` = '3' AND `mingcheng` LIKE '%python%' ESCAPE '!' ORDER BY `pid` asc, `time` desc LIMIT 12

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值