- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不是该项目的一部分,而且我对 yii 真的很陌生,所以找到所有东西的位置一直是一个挑战。
每次我在搜索栏中输入内容时,php 都会给我以下错误:
CDbCommand failed to execute the SQL statement: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'first_name' in 'where clause'. The SQL statement executed was: SELECT * FROM `persons` `t` WHERE CONCAT(upper(first_name),' ',upper(last_name)) like :tag or upper(email) like :tag
.tag {
08 background-color: yellow;
09 }
10 </style>
11 -->
12 <?php
13 $this->breadcrumbs=array(
14 'Search'=>array('/search'),
15 'Search',
16 );?>
17
18
19 <?php if (($personDataProvider->itemCount + //ERROR POINTS HERE
20 //$galleryDataProvider->itemCount +
21 $blogDataProvider->itemCount +
22 $forumDataProvider->itemCount +
23 $announcementDataProvider->itemCount +
24 $pollsDataProvider->itemCount +
25 $eventsDataProvider->itemCount +
26 $jobsDataProvider->itemCount) == 0) {
27 ?>
28
29 <div>
30
31 <h2 style="color:#259CB1">No Results Found for <i><?=$tag?></i>.</h2>
作为额外引用,我将把我的 PersonController 类放在这里,因为我真的很困惑这些数据提供者的位置!
public function actionIndex()
{
$dataProvider=new CActiveDataProvider('Persons');
$this->render('index',array(
'dataProvider'=>$dataProvider,
));
}
public function loadModel($id)
{
$model=Persons::model()->findByPk($id);
if($model===null)
throw new CHttpException(404,'The requested page does not exist.');
return $model;
}
public function loadModel2($id)
{
$model=User::model()->findByAttributes(array('party_id'=>$id));
if($model===null)
{
echo 'hi';
exit;
throw new CHttpException(404,'The requested page does not exist.');
}
return $model;
}
public function loadModel3($id)
{
$model=Organizations::model()->findByPk($id);
if($model===null)
throw new CHttpException(404,'The requested page does not exist.');
return $model;
}
这是我的模型人物页面:
public function search()
{
// Warning: Please modify the following code to remove attributes that
// should not be searched.
$criteria=new CDbCriteria;
$criteria->compare('party_id',$this->party_id,true);
$criteria->compare('email',$this->email,true);
$criteria->compare('company_name',$this->company_name);
$criteria->compare('middle_name',$this->middle_name,true);
$criteria->compare('dob_year',$this->dob_year);
$criteria->compare('dob_month',$this->dob_month);
$criteria->compare('dob_day',$this->dob_day);
$criteria->compare('nickname',$this->nickname,true);
$criteria->compare('country',$this->country,true);
return new CActiveDataProvider($this, array(
'criteria'=>$criteria,
));
}
我检查了 PersonController 和 search.php 页面,但我不太确定在哪里可以找到 $PersonDataProvider 以便修复此错误!
根据要求,我已经为 actionSearch() 添加了 Controller 并且我看到了“first_name”(它在我的数据库中不存在)但它仍然要求我定义 Person--------------------更新--------------------
public function actionSearch()
{
if(!isset($_GET['tag'])){
Yii::app()->request->redirect(Yii::app()->createUrl('news/index/page/1'));
}
$tag = trim($_GET['tag']);
if(empty($tag)){
Yii::app()->request->redirect(Yii::app()->createUrl('news/index/page/1'));
}
$conditionforadmin = '';
if(Yii::app()->user->isAdmin() == 0)
{
$conditionforadmin = 'and end_date > now() ';
}
$personDataProvider = new CActiveDataProvider('Persons',array(
'criteria'=>array(
'condition'=>'CONCAT(upper(first_name),\' \',upper(last_name)) like :tag or upper(email) like :tag',
'params'=>array (
':tag' => strtoupper('%'.$tag.'%')
),
),
'pagination'=>false,
));
$blogDataProvider = new CActiveDataProvider('Blog',array(
'criteria'=>array(
'condition'=>'upper(title) like :tag or upper(content) like :tag',
//'condition'=>'upper(title) like :tag',
'params'=>array (
':tag' => strtoupper('%'.$tag.'%')
),
),
'pagination'=>false,
));
$forumDataProvider = new CActiveDataProvider('Forum',array(
'criteria'=>array(
'condition'=>'upper(title) like :tag or upper(content) like :tag or upper(category) like :tag',
//'condition'=>'upper(title) like :tag',
'params'=>array (
':tag' => strtoupper('%'.$tag.'%')
),
),
'pagination'=>false,
));
$annconditionview = Persons::model()->get_view_condition('Announcement');
$announcementDataProvider = new CActiveDataProvider('Announcement',array(
'criteria'=>array(
'condition'=>'upper(title) like :tag or upper(content) like :tag '.$annconditionview,
'params'=>array (
':tag' => strtoupper('%'.$tag.'%')
),
),
'pagination'=>false,
));
/*
$galleryDataProvider = new CActiveDataProvider('Gallery',array(
'criteria'=>array(
'condition'=>'upper(title) like :tag',
'params'=>array (
':tag' => strtoupper('%'.$tag.'%')
),
),
'pagination'=>false,
));
*
*/
$pollconditionview = Persons::model()->get_view_condition('Polls');
$pollsDataProvider = new CActiveDataProvider('Polls',array(
'criteria'=>array(
'condition'=>'upper(title) like :tag or upper(content) like :tag '.$conditionforadmin.$pollconditionview,
//'condition'=>'upper(content) like :tag',
'params'=>array (
':tag' => strtoupper('%'.$tag.'%')
),
),
'pagination'=>false,
));
$evtconditionview = Persons::model()->get_view_condition('Events');
$eventsDataProvider = new CActiveDataProvider('Events',array(
'criteria'=>array(
'condition'=>'upper(title) like :tag or upper(content) like :tag '.$evtconditionview,
'params'=>array (
':tag' => strtoupper('%'.$tag.'%')
),
),
'pagination'=>false,
));
$job_tags = SystemParameters::model()->findByAttributes(array('name'=>'job_search_tag'))->value;
$job_tags_arr = explode(',', $job_tags);
//$tag_arr = explode(' ', $tag);
$tag_for_job = $tag;
$look_for_job = FALSE;
foreach($job_tags_arr as $v){
//if(in_array($v, $tag_arr)){
if($v == $tag){
$look_for_job = TRUE;
}
}
if($look_for_job){
$tag_for_job = '';
}
$jobsDataProvider = new CSqlDataProvider('Select *
FROM jobs
WHERE upper(job_title) LIKE "%'.strtoupper($tag_for_job).'%"',array(
'totalItemCount'=> Yii::app()->db->createCommand('Select count(*)
FROM jobs
WHERE upper(job_title) LIKE "%'.strtoupper($tag_for_job).'%"')->queryScalar(),
'pagination'=>false,
));
$this->render('search',array(
'tag'=>$tag,
'personDataProvider'=>$personDataProvider,
'blogDataProvider'=>$blogDataProvider,
'forumDataProvider'=>$forumDataProvider,
'announcementDataProvider'=>$announcementDataProvider,
//'galleryDataProvider'=>$galleryDataProvider,
'pollsDataProvider'=>$pollsDataProvider,
'eventsDataProvider'=>$eventsDataProvider,
'jobsDataProvider'=>$jobsDataProvider,
'look_for_job'=>$look_for_job
));
}
最佳答案
根据评论中的讨论,您必须按以下方式更改代码:在 Controller 中:
$personDataProvider = new CActiveDataProvider('Persons',array(
'criteria'=>array(
'condition'=>'company_name like :tag or upper(email) like :tag',
'params'=>array (
':tag' => strtoupper('%'.$tag.'%')
),
),
'pagination'=>false,
));
然后在模型中:注释掉不需要的条件,因为我们已经在条件部分检查了这两个字段。
$criteria->compare('party_id',$this->party_id,true);
// $criteria->compare('email',$this->email,true);
// $criteria->compare('company_name',$this->company_name);
$criteria->compare('middle_name',$this->middle_name,true);
$criteria->compare('dob_year',$this->dob_year);
$criteria->compare('dob_month',$this->dob_month);
$criteria->compare('dob_day',$this->dob_day);
$criteria->compare('nickname',$this->nickname,true);
$criteria->compare('country',$this->country,true);
关于php - 我被要求修复搜索功能中的错误。我在 yii 上不断收到 CDbException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21228346/
我有一个类和构造函数,如下所示: def init(log, edge): if edge: return Helper(log, edge) return Booka
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
有人知道在 mongo 上安装标准 ubuntu 需要多少磁盘空间和内存吗?试图找出我的 VPS 需求... 最佳答案 没有最低要求,但我不建议在与您的网络服务器相同的机器上运行 Mongo。 Mon
我的 Django 项目有一个虚拟环境,但是当我 pip 击 pip freeze 时,我得到了一个必须是全局站 pip 包列表的东西,包括太多包,比如ubuntu包和这么多不相关的东西。无论 vir
我曾尝试在 Heroku 上部署我的应用程序,但 smth 出错了。 错误:找不到满足要求的版本 get==2019.4.13(来自 -r/tmp/build_53ad6d03_/requiremen
我无法将 semantic-ui-calendar npm 模块加载到我的应用程序中。 我已经使用脚本标签成功地将它加载到我的 HTML 中, 但每次我尝试将它加载到我的应用程序中时,我都会出错。 在
如何修复 php.ini 中“require”函数内的地址?它进行故障排除并显示错误: 警告:require (..) 无法打开流:没有这样的文件或目录。 文件“db_connection.php”工
我有一个在 Node.js 应用程序中使用的外部库 ( Objection.js )。我创建了一个基本模型类,它为我的实体模型扩展了 Objection 的 Model 类: const { Mode
有谁知道在哪里可以找到RHEL5的GLIBC2.7,如果没有这个,Android模拟器将无法启动。它会给出一条消息,要求GLIBC 2.7或更高版本。 我尝试在网上搜索,但没有找到 最佳答案 我也遇到
Android 设备是否有任何要求/指南?例如按钮数量或所需的最少按钮数量。 还有没有菜单和后退按钮的安卓设备吗? (我知道就可用性而言,没有菜单/后退按钮会杀死大多数应用程序,我只是想了解更多有关该
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我正在尝试在我的 Linux Mint 发行版上安装一个 python 模块“pyAudioProcessing”(https://github.com/jsingh811/pyAudioProces
我已经创建了我的第一个 composer 包,它具有 MySQL 和 MongoDB 的功能,但是,它不需要两者。我意识到有人可能只想将这个包与两个数据库之一一起使用,目前我有: "require":
我想调试以下函数,但假设在调试器中查看 moreajaj 的参数等于什么(假设不像在这个人为的示例中那么明显)是有用的。我可以在调试器框架中打印它,但是在每个参数的每个框架中都这样做很烦人。在宣布每一
我有一些生成的 GNUmakefiles,我需要从中提取变量的值。 有没有一种简单的方法可以在不修改 makefile 的情况下查看变量的值? 仅供引用,变量包含 emacs c-macro-expa
我正在使用 aspell 在 Linux 上拼写检查 LaTeX 文档。我的文档经常包含各种编程语言的代码示例,我希望 aspell 在拼写检查时简单地跳过这些行。 我可以在文档中写些什么来关闭一段文
我有一个包含多个列的数据集... 一列是具有重复值的主石斑鱼列,另一列是具有 bool 值 (1,0) 的 NUMBER,如下所示: grp bool --- ---- A 1 A 1 A
出于测试目的,我正在尝试删除一些 amd 模块并从服务器重新加载更新版本 - 目的是不刷新浏览器。 我目前正在执行以下操作,但浏览器仍然没有从网络重新加载项目。 var scripts = docum
当我键入irb> require 'rubygems'时,它返回false。我的Rails应用程序中有很多 gem ,这些 gem 显然可以正常工作-耙子,activerecord等。这里可能出什么问
我是一名优秀的程序员,十分优秀!