简体   繁体   English

查询生成器Codeigniter 3

[英]Query Builder Codeigniter 3

I this mysql query 我这个mysql查询

SELECT project.title project_title, category.category, project_details.description description, SUM(project_details.quantity) total_quantity, project_details.unit, SUM(project_details.price) total_price, SUM(project_details.jan) total_jan, SUM(project_details.feb) total_feb, SUM(project_details.mar) total_mar, SUM(project_details.apr) total_apr, SUM(project_details.may) total_may, SUM(project_details.jun) total_jun, SUM(project_details.jul) total_jul, SUM(project_details.aug) total_aug, SUM(project_details.sep) total_sep, SUM(project_details.oct) total_oct, SUM(project_details.nov) total_nov, SUM(project_details.dec) total_dec
FROM project_details
JOIN project ON project_details.project_id = project.id
JOIN category ON project_details.category_id = category.id
JOIN user ON project.user_id = user.id
RIGHT JOIN office ON user.office_id = office.id
WHERE EXISTS 
    (
        SELECT t1.id id1, t2.id id2, t3.id id3, t4.id id4, t5.id id5
        FROM user t1
        LEFT JOIN user t2 ON t2.reports_to = t1.id
        LEFT JOIN user t3 ON t3.reports_to = t2.id
        LEFT JOIN user t4 ON t4.reports_to = t3.id
        LEFT JOIN user t5 ON t5.reports_to = t4.id
        WHERE t1.id = 81
    )
    AND project.approval_status = 22 AND project.reason_for_rejection IS NULL
GROUP BY project.id, project_details.description
ORDER BY project_details.category_id

However I cannot find any documentation in Codeigniter 3.0 where I can find WHERE EXISTS . 但是,我在Codeigniter 3.0中找不到任何文档,在这里可以找到WHERE EXISTS I already checked this https://www.codeigniter.com/userguide3/database/query_builder.html but there are non. 我已经检查了这个https://www.codeigniter.com/userguide3/database/query_builder.html,但是没有。

This is my code right now 这是我现在的代码

$this->db->select('project.title project_title, category.category, project_details.description description, SUM(project_details.quantity) total_quantity, project_details.unit, SUM(project_details.price) total_price, SUM(project_details.jan) total_jan, SUM(project_details.feb) total_feb, SUM(project_details.mar) total_mar, SUM(project_details.apr) total_apr, SUM(project_details.may) total_may, SUM(project_details.jun) total_jun, SUM(project_details.jul) total_jul, SUM(project_details.aug) total_aug, SUM(project_details.sep) total_sep, SUM(project_details.oct) total_oct, SUM(project_details.nov) total_nov, SUM(project_details.dec) total_dec');
$this->db->from('project_details');
$this->db->join('project', 'project_details.project_id = project.id');
$this->db->join('category', 'project_details.category_id = category.id');
$this->db->join('user', 'project.user_id = user.id');
$this->db->join('office', 'user.office_id = office.id', 'right');
// THIS IS WHERE I WANT TO PUT THE WHERE EXISTS
$this->db->where('project.approval_status', $user_id);
$this->db->where('project.reason_for_rejection IS NULL', NULL, TRUE);
$this->db->group_by('project.id');
$this->db->group_by('project_details.description');
$this->db->order_by('project_details.category_id');
$query = $this->db->get();
return $query->result();

Can someone please help how can I achieve this in codeigniter? 有人可以帮我如何在codeigniter中实现吗? Advanced thanks. 先进的谢谢。

When you have a really large query, or the is no built-in function on the query builder made for your purpose you can always use: 当您有非常大的查询时,或者在查询构建器中没有is内置函数供您使用时,您始终可以使用:

$query = $this->db->query('your large query');

You also should be aware of the injections so you should also read this post 您还应该注意注射剂,因此您也应该阅读这篇文章

This explains pretty well how to use $this->db->query method against sql injections. 这很好地解释了如何对SQL注入使用$this->db->query方法。

Hope this helps 希望这可以帮助

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM