首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >( (Where and Where) OR (Where and Where) ) CodeIgniter

( (Where and Where) OR (Where and Where) ) CodeIgniter
EN

Stack Overflow用户
提问于 2020-07-26 14:55:02
回答 1查看 41关注 0票数 0

这是laravel的引用:( (Where and Where) OR (Where and Where) ) Laravel 5.2

这是我的代码:

代码语言:javascript
复制
$this->db->select('BaseTbl.*');
$this->db->from('tablename as BaseTbl');
// *************** WHERE THIS Based on sendMeetingSchedule = 'YES' ****************
$this->db->where('BaseTbl.companyId', 10);
$this->db->where_not_in('BaseTbl.status', array('Draft'));
$this->db->where('BaseTbl.description !=', '');
$this->db->where('BaseTbl.sendMeetingSchedule', 'Yes');
// *************** OR THIS Based on sendMeetingSchedule = 'NO' ****************
$this->db->or_where('BaseTbl.sendMeetingSchedule', 'No');
$this->db->where('BaseTbl.status', 'Pending Meeting');
$this->db->order_by('BaseTbl.id', 'desc');

这是我的查询输出:

代码语言:javascript
复制
SELECT `BaseTbl`.* FROM `tablename` as `BaseTbl` WHERE `BaseTbl`.`companyId` = '10' AND `BaseTbl`.`status` NOT IN('Draft') AND `BaseTbl`.`description` != '' AND `BaseTbl`.`sendMeetingSchedule` = 'Yes' OR `BaseTbl`.`sendMeetingSchedule` = 'No' AND `BaseTbl`.`status` = 'Pending Meeting' ORDER BY `BaseTbl`.`id` DESC

我想要基于sendMeetingSchedule列的where子句。如果它是'YES‘,那么运行上面的where子句,否则在codeigniter中运行下面的where子句。

这是我想要的查询输出:

代码语言:javascript
复制
SELECT `BaseTbl`.* FROM `tablename` as `BaseTbl` WHERE (`BaseTbl`.`companyId` = '10' AND `BaseTbl`.`status` NOT IN('Draft') AND `BaseTbl`.`description` != '' AND `BaseTbl`.`sendMeetingSchedule` = 'Yes') OR (`BaseTbl`.`sendMeetingSchedule` = 'No' AND `BaseTbl`.`status` = 'Pending Meeting') ORDER BY `BaseTbl`.`id` DESC

注意:不使用自定义where子句:

代码语言:javascript
复制
$this->db->where('MATCH (field) AGAINST ("value")', NULL, FALSE);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-07-26 15:08:31

左方括号和右方括号需要使用group_start()group_end()

代码语言:javascript
复制
$this->db->select('BaseTbl.*');
$this->db->from('tablename as BaseTbl');

// *************** WHERE THIS Based on sendMeetingSchedule = 'YES' ****************
$this->db->group_start() // Open bracket;
$this->db->where('BaseTbl.companyId', 10);
$this->db->where_not_in('BaseTbl.status', array('Draft'));
$this->db->where('BaseTbl.description !=', '');
$this->db->where('BaseTbl.sendMeetingSchedule', 'Yes');
$this->db->group_end() // Close bracket;

// *************** OR THIS Based on sendMeetingSchedule = 'NO' ****************
$this->db->or_group_start() // Open bracket;
$this->db->where('BaseTbl.sendMeetingSchedule', 'No');
$this->db->where('BaseTbl.status', 'Pending Meeting');
$this->db->group_end() // Close bracket;
$this->db->order_by('BaseTbl.id', 'desc');

注意:适用于Codeigniter 3.0.3或更高版本

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63097049

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档