- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用codeigniter框架的事件类来构建查询,我的查询低于维护,输出和预期输出不同,我认为浏览器中的查询结果和phpmyadmin中的查询结果应该相同,但这里不是:
function searchProperty($data=array()){
if(!empty($data['status']) && $data['status']=="Occupied"){
$get_prop_ids = $this->getOccupiedProperty($data);
}
extract($data);
$this->db->select('p.*');
$this->db->from('properties p');
$this->db->join('prop_address pa', 'pa.prop_id = p.id','INNER');
$this->db->join('prop_details pd', 'pd.prop_id = p.id','INNER');
$this->db->join('property_type ptype', 'ptype.id = p.property_type_id');
$get_post_codes = array();
$this->db->where('p.status', 'Available');
$prop_ids = '0';
$post_codes_search = array();
$search_tearms = array();
if(empty(!$countkey)){
$postcode_1_condition = "";
$location_condition = "";
$display_addr_condition = "";
for($i=0; $i < $countkey; $i++){
$var_data = trim($data['search_'.$i]);
$search_tearms[] = $var_data;
$is_complete_address = $this->IsDisplayAddress($var_data);
if(!$is_complete_address){
$is_postCode = $this->isPostcode($var_data);
if($is_postCode){
$prop_ids_postcode = $this->getPropFromProVeiw('postcode',$var_data);
$post_codes_search[] = $var_data;
if(count($prop_ids_postcode)){
$prop_ids .= ','.implode(',',$prop_ids_postcode);
}
}else{
$is_location = $this->isLocation($var_data);
if($is_location){
$prop_ids_location = $this->getPropFromProVeiw('location',$var_data);
$prop_ids .= ','.implode(',',$prop_ids_location);
//var_dump($prop_ids);
}else{
$prop_ids_area = $this->getPropFromProVeiw('area',$var_data);
if(count($prop_ids_area)){
$prop_ids .= ','.implode(',',$prop_ids_area);
}else{
$prop_ids_street = $this->getPropFromProVeiw('street',$var_data);
$prop_ids .= ','.implode(',',$prop_ids_street);
}
}
}
}else{
$prop_ids .= $is_complete_address;
}
}
$prop_ids = trim($prop_ids,',');
$prop_ids = str_replace(",,,",",",$prop_ids);
$prop_ids = str_replace(",,",",",$prop_ids);
$prop_ids = explode(",",$prop_ids); //p($prop_ids);
$prop_ids = array_unique($prop_ids);
$additional_ids = implode(",",$prop_ids);
$this->db->where("p.id in ($additional_ids) ");
}
if(!empty($min)){
$this->db->where('pd.price_pw >=', $min);
}
if(!empty($max)){
$this->db->where('pd.price_pw <=', $max);
}
/*
$bed = (isset($bed)) ? $bed : '';
if($bed != '' && $bed != 4){
$this->db->where('pd.bedrooms', $bed);
} elseif ($bed != '' && $bed == 4) {
$this->db->where('pd.bedrooms >=', $bed);
}*/
if(!empty($bed) || $bed=='0'){
$bed = (isset($bed)) ? $bed : [];
if(!is_array($bed)){
$bed = explode(',',$bed);
}
if(in_array(4,$bed)){
$bed[] = 5;
$bed[] = 6;
$bed[] = 7;
$bed[] = 8;
$bed[] = 9;
$bed[] = 10;
}
if(count($bed)){
$beds = implode(',',$bed);
$this->db->where("pd.bedrooms in ($beds)");
}
}
if(!empty($type) && $type == 'apartment'){
$this->db->where('ptype.prop_category', 'Apartment');
} elseif(!empty($type) && $type == 'house') {
$this->db->where('ptype.prop_category', 'House');
}
$tag = (!empty($tag)) ? $tag : "";
if($tag == 'furnished'){
$this->db->where('pd.furnished_type_id in (0,1)');
} elseif($tag == 'part-furnished') {
$this->db->where('pd.furnished_type_id in (1)');
} elseif($tag == 'unfurnished') {
$this->db->where('pd.furnished_type_id', 2);
} elseif($tag == 'furnished-unFurnished') {
$this->db->where('pd.furnished_type_id in (0,1,2,4)');
}
$this->db->where('pa.display_address !=', '');
//$this->db->where('pa.latitude !=', '');
//$this->db->where('pa.longitude !=', '');
$this->db->where('pa.postcode_1 !=', '');
if(!empty($get_prop_ids)){
$this->db->where("pd.price > 0 or p.id in ($get_prop_ids) ");
}else{
$this->db->where('pd.price >', 0);
}
if(!empty($sort) && $sort == 'highest'){
$this->db->order_by('pd.price_pw', 'desc');
} else {
$this->db->order_by('pd.price_pw', 'asc');
}
$this->db->group_by('p.agent_ref,p.id');
$tempdb = clone $this->db;
if(!empty($loadMorePage)) {
if($loadMorePage == 1){
$this->db->limit(10, 0);
} else {
$page_limit = 10*($loadMorePage-1);
$this->db->limit(10, $page_limit);
}
}
$query = $this->db->get();
$sql = $this->db->last_query();
$queryCount = $tempdb->get();
if( $query->num_rows() > 0 ){
$count = $queryCount->num_rows();
$result = $query->result();
$propertyData = $result;
} else {
$count = 0;
$propertyData = array();
}
//p($search_tearms);
$get_post_codes = $this->getAllpostCodes($propertyData,$post_codes_search,$search_tearms);
return array('count' => $count, 'propertyData' => $propertyData, 'query'=>$sql, 'postcodes'=>$get_post_codes);
}
Controller 功能是:
public function search_post(){
$postData = $this->post(); //p($postData);
$this->load->model('properties_model', 'properties');
$this->load->model('prop_details_model', 'prop_details');
$this->load->model('prop_address_model', 'prop_address');
$this->load->model('prop_features_model', 'prop_features');
$this->load->model('prop_media_model', 'prop_media');
$this->load->model('offices_model', 'office');
$this->load->model('Main_postcodes_model', 'main_postcode');
$loadMorePage = !empty($postData['loadMorePage']) ? $postData['loadMorePage'] : 1;
$properties = $this->properties->searchProperty($postData); //p($properties);
$property = $properties['propertyData'];
$count = $properties['count'];
foreach($property as $index => $prop){
$property[$index]->detail = $this->prop_details->getByPropid( $prop->id, $this->role_id );
$property[$index]->address = $this->prop_address->getByPropid( $prop->id );
$property[$index]->features = $this->prop_features->getByPropid( $prop->id );
$property[$index]->media = $this->prop_media->getMediaByPropid( $prop->id );
$property[$index]->mediaEpc = $this->prop_media->getMediaEPCByPropid( $prop->id );
$property[$index]->floorPlan = $this->prop_media->getMediaFPByPropid( $prop->id );
$property[$index]->branch = $this->office->getByPropcoCode( $prop->branch_id );
}
$similerProperties = array();
if(!empty($properties['postcodes'])){
$postData['min'] = (!empty($postData['min'])) ? $postData['min'] : '';
$postData['max'] = (!empty($postData['max'])) ? $postData['max'] : '';
$postData['type'] = (!empty($postData['type'])) ? $postData['type'] : '';
$postData['bed'] = (isset($postData['bed'])) ? $postData['bed'] : '';
$postData['type'] = (!empty($postData['type'])) ? $postData['type'] : '';
$postData['tag'] = (!empty($postData['tag'])) ? $postData['tag'] : '';
$postData['count_to_show'] = 10 - $count;
$postData['postcodes'] = $properties['postcodes'];
$postData['query'] = $properties['query'];
$similerProperties = $this->properties->similerPropSearch($postData );
$similerProperties = $similerProperties['propertyData'];
foreach($similerProperties as $index => $prop){
$similerProperties[$index]->detail = $this->prop_details->getByPropid( $prop->id, $this->role_id );
$similerProperties[$index]->address = $this->prop_address->getByPropid( $prop->id );
$similerProperties[$index]->features = $this->prop_features->getByPropid( $prop->id );
$similerProperties[$index]->media = $this->prop_media->getMediaByPropid( $prop->id );
$similerProperties[$index]->mediaEpc = $this->prop_media->getMediaEPCByPropid( $prop->id );
$similerProperties[$index]->floorPlan = $this->prop_media->getMediaFPByPropid( $prop->id );
$similerProperties[$index]->branch = $this->office->getByPropcoCode( $prop->branch_id );
}
}
if($loadMorePage > 1){
$properties = $property;
$myCarouselIndex = 10*($loadMorePage-1);
$this->_view_data['properties'] = $properties;
$this->_view_data['myCarouselIndex'] = $myCarouselIndex;
$this->_view_data['query'] = $postData['query'];
$this->_view_data['loadMorePage'] = $loadMorePage;
$propertyHtml = $this->load->view('frontend/property/loadmore-search', $this->_view_data, true);
echo $propertyHtml;
} else {
$response = array('type' => 'success', 'query'=>$properties['query'], 'message' => "", 'data' => $property, 'count' => $count, 'similerProperties' => $similerProperties);
$this->output->set_content_type('application/json')->set_output(json_encode($response));
}
}
输出如下:
Array
(
[propertyData] => Array
(
[0] => stdClass Object
(
[id] => 1375
[agent_ref] => BR18739_000013590
[slug] =>
[branch_id] => BR18739
[status_id] => 0
[property_type_id] => 28
[is_published] => 1
[date_available] => 2018-09-10 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Beaufort Park
[status] => Available
[propco_created_at] => 2018-09-10 08:49:43
[propco_updated_at] => 2018-09-20 07:20:25
[created_by] => 3
[created_at] => 2018-10-01 03:06:12
[updated_by] => 3
[updated_at] => 2018-10-01 03:06:12
)
[1] => stdClass Object
(
[id] => 1129
[agent_ref] => 22864_000013421
[slug] =>
[branch_id] => 22864
[status_id] => 0
[property_type_id] => 28
[is_published] => 1
[date_available] => 2018-07-30 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Kew
[status] => Available
[propco_created_at] => 2018-07-30 06:53:40
[propco_updated_at] => 2018-09-04 11:53:59
[created_by] => 3
[created_at] => 2018-10-01 03:02:56
[updated_by] => 3
[updated_at] => 2018-10-01 03:02:56
)
[2] => stdClass Object
(
[id] => 1332
[agent_ref] => 22864_000013570
[slug] =>
[branch_id] => 22864
[status_id] => 0
[property_type_id] => 28
[is_published] => 1
[date_available] => 2018-09-04 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Kew
[status] => Available
[propco_created_at] => 2018-09-04 13:30:28
[propco_updated_at] => 2018-09-10 08:15:49
[created_by] => 3
[created_at] => 2018-10-01 03:06:06
[updated_by] => 3
[updated_at] => 2018-10-01 03:06:06
)
[3] => stdClass Object
(
[id] => 1414
[agent_ref] => 22864_000013611
[slug] =>
[branch_id] => 22864
[status_id] => 0
[property_type_id] => 28
[is_published] => 1
[date_available] => 2018-09-14 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Kew
[status] => Available
[propco_created_at] => 2018-09-14 07:52:15
[propco_updated_at] => 2018-09-20 08:42:53
[created_by] => 3
[created_at] => 2018-10-01 03:06:21
[updated_by] => 3
[updated_at] => 2018-10-01 03:06:21
)
[4] => stdClass Object
(
[id] => 1404
[agent_ref] => 22864_000013605
[slug] =>
[branch_id] => 22864
[status_id] => 0
[property_type_id] => 28
[is_published] => 1
[date_available] => 2018-09-13 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Kew
[status] => Available
[propco_created_at] => 2018-09-13 06:19:20
[propco_updated_at] => 2018-09-13 06:38:50
[created_by] => 3
[created_at] => 2018-10-01 03:06:17
[updated_by] => 3
[updated_at] => 2018-10-01 03:06:17
)
[5] => stdClass Object
(
[id] => 1318
[agent_ref] => BR22545_000003107
[slug] =>
[branch_id] => BR22545
[status_id] => 5
[property_type_id] => 9
[is_published] => 1
[date_available] => 2018-11-28 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Canary Wharf
[status] => Available
[propco_created_at] => 2013-05-01 14:10:13
[propco_updated_at] => 2018-09-10 07:14:17
[created_by] => 3
[created_at] => 2018-10-01 03:00:38
[updated_by] => 3
[updated_at] => 2018-10-01 03:00:38
)
[6] => stdClass Object
(
[id] => 1212
[agent_ref] => BR18739_000000626
[slug] =>
[branch_id] => BR18739
[status_id] => 5
[property_type_id] => 28
[is_published] => 1
[date_available] => 2018-09-19 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Beaufort Park
[status] => Available
[propco_created_at] => 2012-08-16 15:20:01
[propco_updated_at] => 2018-09-17 10:33:01
[created_by] => 3
[created_at] => 2018-10-01 03:00:43
[updated_by] => 3
[updated_at] => 2018-10-01 03:00:43
)
[7] => stdClass Object
(
[id] => 1403
[agent_ref] => BR18739_000006003
[slug] =>
[branch_id] => BR18739
[status_id] => 5
[property_type_id] => 9
[is_published] => 1
[date_available] => 2018-09-30 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Beaufort Park
[status] => Available
[propco_created_at] => 2016-01-22 10:47:09
[propco_updated_at] => 2018-09-20 07:40:16
[created_by] => 3
[created_at] => 2018-10-01 03:02:37
[updated_by] => 3
[updated_at] => 2018-10-01 03:02:37
)
[8] => stdClass Object
(
[id] => 7
[agent_ref] => BR17546_000002226
[slug] =>
[branch_id] => BR17546
[status_id] => 0
[property_type_id] => 9
[is_published] => 1
[date_available] => 2018-08-30 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Kensington
[status] => Available
[propco_created_at] => 2012-09-26 14:39:09
[propco_updated_at] => 2018-08-30 17:08:04
[created_by] => 3
[created_at] => 2018-10-01 03:00:06
[updated_by] => 3
[updated_at] => 2018-10-01 03:00:06
)
[9] => stdClass Object
(
[id] => 1177
[agent_ref] => 22582_000002037
[slug] =>
[branch_id] => 22582
[status_id] => 5
[property_type_id] => 9
[is_published] => 1
[date_available] => 2018-08-21 00:00:00
[channel_id] => 2
[let_type_id] => 1
[location_name] => Surrey Quays (Surrey Quays)
[status] => Available
[propco_created_at] => 2012-07-06 17:08:07
[propco_updated_at] => 2018-08-13 13:03:25
[created_by] => 3
[created_at] => 2018-10-01 03:05:03
[updated_by] => 3
[updated_at] => 2018-10-01 03:05:03
)
)
[query] => SELECT `p`.*
FROM `bnr_properties` `p`
JOIN `bnr_prop_address` `pa` ON `pa`.`prop_id` = `p`.`id`
JOIN `bnr_prop_details` `pd` ON `pd`.`prop_id` = `p`.`id`
JOIN `bnr_property_type` `ptype` ON `ptype`.`id` = `p`.`property_type_id`
WHERE `p`.`status` = 'Available'
AND `pa`.`display_address` != ''
AND `pa`.`postcode_1` != ''
AND `pd`.`price` >0
GROUP BY `p`.`agent_ref`, `p`.`id`
ORDER BY `pd`.`price_pw` ASC
LIMIT 10, 10
)
最佳答案
您需要使用第三个参数指定要使用的 JOIN
If you need a specific type of JOIN you can specify it via the third parameter of the function. Options are: left, right, outer, inner, left outer, and right outer.
$this->db->join('prop_address pa', 'pa.prop_id = p.id','INNER');
In MySQL writing JOIN unqualified implies INNER JOIN. In other words the INNER in INNER JOIN is optional.
关于php - CI 查询结果给出意外结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52585641/
我在使用带有 vector STL 的迭代器时遇到了这个错误。 代码:- #include #include void print_vec(std::vector vec) { auto
JAVA:两个引用“p”&&“pp”之间有区别吗? PrintStream p = new PrintStream(System.out); p.println("lol");
我尝试从主分支中拉出,但收到错误消息: $ git --no-optional-locks -c color.branch=false -c color.diff=false -c color.sta
我面临着一个让我抓狂的问题! 我有一个函数,这个: void load_weapons3(t_env *e, char *name, int x, t_weapon *w) { char
我正在尝试使用 CUDA 中的最小值、最大值、总和和平均值实现并行归约。 这是我目前的主要代码片段。 int main() { const auto count = 8; const
我知道 double free 或 corruption 错误通常是对 big 3 的违规,但在这种情况下,我找不到违规发生的地方。我有一个复制构造函数、析构函数和赋值运算符,适用于任何处理指针的东西
GTK+ 中的“focus”和“focus-in(out)-event”信号有什么区别?哪个先发射?它们与键盘(TAB)和鼠标点击有什么关系。他们互相依赖吗? 我问这个是因为我想在顶层窗口中跟踪当前聚
*** glibc detected *** /home/ghoshs/workspace/Simulator/Debug/Simulator: double free or corruption (
#include #include #include #include using namespace std; #define MAX_WEIGHT 1000000 class Set {
我在服务器上有两个分支一个叫 R2 的分支和一个叫 DEV 的分支我无意中登录了错误的服务器,进入了存储库并执行了GIT pull 源开发但是存储库在 R2 上。所以我意识到我的错误然后尝试通过做一个
我有一个包含循环的大约 1000 个顶点和 3000 个边的有向图。 我试图从给定的顶点找到所有下游(出)路径。 使用以下 Gremlin 查询时 g.V(45712).repeat(out().si
使用 Delphi XE 2 我试图确定缩放方向以将缩放效果应用于图像(TImage),但没有找到执行此操作的函数,并且图像的 OnGesture 事件中的 EventInfo 属性没有此信息. 我见
我正在尝试创建一个 Zoom_image 函数,它使用离散傅里叶变换来缩放灰度图像。如果图像大小小于或等于 4*4 但大小增加,我包含的代码可以工作。它给出“双重释放或损坏(出)中止(核心转储)”错误
当我执行 popAll 函数时,出现以下错误: 双重释放或腐败(出)中止(核心转储) 我想我已经将错误来源缩小到了这个函数。 IntegerStack 是我制作的一个简单的 ADT,其中包含一个名为
我有网络开发背景,我正在尝试创建类似于 this technique 的东西适用于 iOS(使用 Cocoa/Obj C)。我在谷歌搜索资源时遇到了很多困难,因为 iOS 中的“视差”往往指的是 iO
我想实现一个 faceted search对于我的一个项目。我正在使用 PHP5、Mysql 和 Symfony 1.4。显然社区指向Apache Solr这似乎正是我想要完成的。 问题是该网站将在不
我知道有 questions floating around当您没有提供明确的分支名称时,关于来自特定分支的 git pull,但是我想知道即使用户确实指定了不同的分支,是否也可以强制 pull 分支
我正在尝试将我的更改推送到 NAS 上的存储库。它以我无法理解的方式失败。 documentation声明默认情况下 push 仅适用于快进更新。很公平。所以我做了一个 git pull(我的 Rem
我刚开始使用 Oracle 的 Coherence 缓存,我注意到这一点:如果我在缓存中放入一个 ConcurrentHashMap 对象,当我检索它时,我可以看到它被转换为一个普通的 HashMap
我尝试创建一个连接到数据库的线程,从那里获取一些数据并打印到控制台。问题是当该线程完成时抛出异常: 双重免费或腐败(出局)中止(核心转储) 我尝试使用 sqlite3 和 pthread,但这两个并不
我是一名优秀的程序员,十分优秀!