热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php–使用CDbCriteria和CActiveDataProvider进行连接的Yii

这个问题似乎弹出了很多,但没有一个答案帮助我解决了我的问题.摘要我正在使用Yii创建一个应用程序;我有三张桌子,我正在尝试加入并过滤其中两张;我正在尝试使用CDbCriter

这个问题似乎弹出了很多,但没有一个答案帮助我解决了我的问题.

摘要

>我正在使用Yii创建一个应用程序;
>我有三张桌子,我正在尝试加入并过滤其中两张;
>我正在尝试使用CDbCriteria和CActiveDataProvider来进行连接和过滤;
>我有所有表的模型,但是当我尝试加入它们时,我得到一个SQL错误.

我为要加入和过滤的表创建了一个模型.

记录

class Record extends CActiveRecord {
public $owner;
...
public function rules() {
return array(
array('given_name, family_name, dob, gender', 'required'),
array('qr_id, site_id', 'numerical', 'integerOnly' => true),
array('given_name, family_name, madin_name', 'length', 'max' => 100),
array('country_of_birth, country_of_death, title', 'length', 'max' => 45),
array('gender', 'length', 'max' => 5),
array('dod, profile, epitaph', 'safe'),
array('id, qr_id, given_name, family_name, madin_name, dob, dod, country_of_birth, country_of_death, gender, owner', 'safe', 'on' => 'search'),
);
}
...
public function relations() {
return array(
'families_left' => array(self::HAS_MANY, 'Family', 'record_left_id'),
'families_right' => array(self::HAS_MANY, 'Family', 'record_right_id'),
'headstones' => array(self::HAS_MANY, 'Headstone', 'record_id'),
'other_names' => array(self::HAS_MANY, 'OtherName', 'record_id'),
'users' => array(self::MANY_MANY, 'Users', 'record_owner(record_id, user_id)'),
'record_owner' => array(self::HAS_MANY, 'RecordOwner', 'record_id'),
);
}
...
}

RecordOwner

class RecordOwner extends CActiveRecord {
...
public function relations() {
// NOTE: you may need to adjust the relation name and the related
// class name for the relations automatically generated below.
return array();
}
...
}

问题

我有更新搜索在record_owner上添加了一个条件到CDbCriteria,我在record_owner.user_id上添加了一个比较但现在得到SQL错误.

搜索()

public function search() {
// Warning: Please modify the following code to remove attributes that
// should not be searched.
$criteria = new CDbCriteria;
$criteria->compare('id', $this->id);
$criteria->compare('qr_id', $this->qr_id);
$criteria->compare('given_name', $this->given_name, true);
$criteria->compare('family_name', $this->family_name, true);
$criteria->compare('madin_name', $this->madin_name, true);
$criteria->compare('dob', $this->dob, true);
$criteria->compare('dod', $this->dod, true);
$criteria->compare('country_of_birth', $this->country_of_birth, true);
$criteria->compare('country_of_death', $this->country_of_death, true);
$criteria->compare('gender', $this->gender, true);
$criteria->compare('title', $this->title, true);
$criteria->with = array('record_owner');
$criteria->compare( 'record_owner.user_id', $this->owner, true );
return new CActiveDataProvider(
$this,
array(
'criteria' => $criteria,
'pagination' => array(
'pageSize' => Yii::app()->params['pageSize'],
)
)
);
}

SQL错误

CDbCommand failed to execute the SQL statement: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'record_owner.user_id' in 'where clause'. The SQL statement executed was: SELECT `t`.`id` AS `t0_c0`, `t`.`qr_id` AS `t0_c1`, `t`.`given_name` AS `t0_c2`, `t`.`family_name` AS `t0_c3`, `t`.`madin_name` AS `t0_c4`, `t`.`dob` AS `t0_c5`, `t`.`dod` AS `t0_c6`, `t`.`country_of_birth` AS `t0_c7`, `t`.`country_of_death` AS `t0_c8`, `t`.`gender` AS `t0_c9`, `t`.`profile` AS `t0_c10`, `t`.`epitaph` AS `t0_c11`, `t`.`site_id` AS `t0_c12`, `t`.`title` AS `t0_c13` FROM `record` `t` WHERE (record_owner.user_id LIKE :ycp0) ORDER BY `t`.`given_name` LIMIT 25

我该怎么做这个加入和过滤?

解决方法:

添加$criteria-> together = true;到搜索方法.

看一下这个解释:

http://www.yiiframework.com/doc/api/1.1/CDbCriteria#together-detail

特别是,


When this property is not set, if the primary table is limited or

paginated, a SQL statement will be executed for each HAS_MANY

relation. Otherwise, a single SQL statement will be executed for all.


由于您没有设置此值,并且正在使用分页,因此将通过对到达结果的单独查询来获取record_owners.当然,假设查询实际完成了.

通过设置$criteria-> together = true;您强制执行单个查询的查询,这通过执行表连接来完成,这是您希望通过相关表中的一列过滤查询.


推荐阅读
  • 本文介绍了如何使用PHP向系统日历中添加事件的方法,通过使用PHP技术可以实现自动添加事件的功能,从而实现全局通知系统和迅速记录工具的自动化。同时还提到了系统exchange自带的日历具有同步感的特点,以及使用web技术实现自动添加事件的优势。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 本文介绍了在使用Python中的aiohttp模块模拟服务器时出现的连接失败问题,并提供了相应的解决方法。文章中详细说明了出错的代码以及相关的软件版本和环境信息,同时也提到了相关的警告信息和函数的替代方案。通过阅读本文,读者可以了解到如何解决Python连接服务器失败的问题,并对aiohttp模块有更深入的了解。 ... [详细]
  • 深入理解CSS中的margin属性及其应用场景
    本文主要介绍了CSS中的margin属性及其应用场景,包括垂直外边距合并、padding的使用时机、行内替换元素与费替换元素的区别、margin的基线、盒子的物理大小、显示大小、逻辑大小等知识点。通过深入理解这些概念,读者可以更好地掌握margin的用法和原理。同时,文中提供了一些相关的文档和规范供读者参考。 ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
author-avatar
再见WhoWho
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有