Yii2实现让关联字段支持搜索功能的方法

本文实例讲述了Yii2实现让关联字段支持搜索功能的方法。分享给大家供大家参考,具体如下:

这里有两张表,表结构如下,companies_compay_id 为外键

yii2advanced.branches表:

branch_id:int(11)
companies_company_id:int(11)
branch_name:varchar(100)
branch_address:varchar(255)
branch_created_date:datetime
branch_status:enum('active','inactive')

yii2advanced.companies表:

company_id:int(11)
company_name:varchar(100)
company_email:varchar(100)
company_address:varchar(255)
logo:varchar(200)
company_start_date:datetime
company_create_date:datetime
company_status:enum('active','inactive')

在上面表中,可以用companiesCompany.company_name来获取公司名,不过这样是不支持搜索的。

想要支持搜索功能,需要在branches的index视图添加以下代码:

<?= GridView::widget([ 'dataProvider' => $dataProvider, 'filterModel' => $searchModel, 'columns' => [ ['class' => 'yii\grid\SerialColumn'], //添加的代码开始 [ 'label'=>'公司名', 'attribute'=>'companies_company_id', 'value'=>'companiesCompany.company_name' ], //添加的代码结束 'companiesCompany.company_name', // 'branch_id', // 'companies_company_id', 'branch_name', 'branch_address', 'branch_created_date', // 'branch_status', ['class' => 'yii\grid\ActionColumn'], ], ]); ?>

然后修改SearchBranches.php

修改rules方法为:

public function rules() { return [ [['branch_id'], 'integer'], [['branch_name', 'branch_address', 'branch_created_date', 'branch_status','companies_company_id'], 'safe'], ]; }

修改search方法:

public function search($params) { $query = Branches::find(); $dataProvider = new ActiveDataProvider([ 'query' => $query, ]); $this->load($params); if (!$this->validate()) { // uncomment the following line if you do not want to any records when validation fails // $query->where('0=1'); return $dataProvider; } // 添加下面这行代码 $query->joinWith('companiesCompany'); $query->andFilterWhere([ 'branch_id' => $this->branch_id, // 'companies_company_id' => $this->companies_company_id, 'branch_created_date' => $this->branch_created_date, ]); $query->andFilterWhere(['like', 'branch_name', $this->branch_name]) ->andFilterWhere(['like', 'branch_address', $this->branch_address]) ->andFilterWhere(['like', 'branch_status', $this->branch_status]) // 添加下面这行代码 ->andFilterWhere(['like', 'companies.company_name', $this->companies_company_id]); return $dataProvider;

刷新页面即可看到

更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

时间: 2024-07-30 17:33:08

Yii2实现让关联字段支持搜索功能的方法的相关文章

Yii2实现让关联字段支持搜索功能的方法_php实例

本文实例讲述了Yii2实现让关联字段支持搜索功能的方法.分享给大家供大家参考,具体如下: 这里有两张表,表结构如下,companies_compay_id 为外键 yii2advanced.branches表: branch_id:int(11) companies_company_id:int(11) branch_name:varchar(100) branch_address:varchar(255) branch_created_date:datetime branch_status:e

Yii2使用dropdownlist实现地区三级联动功能的方法_php实例

本文实例讲述了Yii2使用dropdownlist实现地区三级联动功能的方法.分享给大家供大家参考,具体如下: 视图部分: <?php use yii\helpers\Url; use yii\widgets\ActiveForm; use yii\helpers\ArrayHelper; use yii\helpers\Html; /* @var $this yii\web\View */ /* @var $model common\search\service\ItemSearch */ /

php利用scws实现mysql全文搜索功能的方法_php技巧

本文实例讲述了php利用scws实现mysql全文搜索功能的方法.分享给大家供大家参考.具体方法如下: scws这样的中文分词插件比较不错,简单的学习了一下,它包涵一些专有名称.人名.地名.数字年代等规则集合,可以直接将语句按这些规则分开成一个一个关键词,准确率在90%-95%之间,按照安装说明把scws的扩展放入php的扩展目录里,下载规则文件和词典文件,并在php配置文件中引用它们,就可以用scws进行分词了. 1) 修改 php 扩展代码以兼容支持 php 5.4.x 2) 修正 php

XP系统各种丢失&quot;搜索&quot;功能解决方法

  XP系统各种丢失"搜索"功能解决方法 单击左下角的开始菜单,单击"运行",在打开的运行对话框中键入%SystemRoot%inf,回车 在打开的文件夹窗口定位到"srchasst.inf"文件 插入系统安装光盘,鼠标右击"srchasst.inf"文件,单击"安装"项 "搜索"功能出错的解决方法 在"开始→运行"对话框中键入"cmd"命令,点击

JS实现表格数据各种搜索功能的方法

 这篇文章主要介绍了JS实现表格数据各种搜索功能的方法,可实现忽略大小写,模糊搜索,多关键搜索等功能,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例讲述了JS实现表格数据各种搜索功能.可忽略大小写,模糊搜索,多关键搜索.分享给大家供大家参考.具体实现方法如下: 代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title&

Yii2-GridView 中让关联字段带搜索和排序功能示例

情境要求: 要在订单(Order)视图的gridview中显示出客户(Customer)姓名,并使其具有与其它字段相同的排序和搜索功能. 数据库结构 订单表order含有字段customer_id 与 客户表customer的id字段关联 首先确保在Order Model中包含以下代码: public function getCustomer() { return $this->hasOne(Customer::className(), ['id' => 'customer_id']); }

yii2组件之下拉框带搜索功能的示例代码(yii-select2)

简单的小功能,但是用起来还是蛮爽的.分享出来让更多的人有更快的开发效率,开开心心快乐编程. 如果你还没有使用过composer,你可就out了,看我的教程分享,composer简直就是必备神奇有木有.都说到这个点上了,我们赶紧使用composer进行安装吧. 不急,先来看看效果图是啥样的,不然都没心情没欲望看下去. 啥玩意,不感兴趣?继续看嘛,看完再操作一边才能觉得好在哪里. 有木有感觉很帅气,当然啦,远远不止,还很上档次用起来效果也是杠杠的有木有. 好了好了,抓紧时间安装,不然聊起来真是没完没

IE浏览器出现“您的浏览器不支持cookies功能”解决方法

  我们在登录某些网站的时候,IE浏览器有时候出现"您的浏览器不支持COOKIES功能"的提示,导致登录失败.这里收集整理了此问题的解决方法: 从"工具"菜单中选择"Internet 选项". 单击"隐私"标签. 单击"高级"按钮,按下列步骤进行设置. 设置完成,重新启动IE即可.(关闭IE再次重新打开) 1:第一步 2:第二步 3:第三步         注:更多精彩教程请关注三联电脑教程栏目

win8系统超级按钮“搜索”功能使用方法

  搜我们电脑里的一切 不管是在传统桌面还是在开始屏幕,我们都可以按下快捷键"Win + Q",快速开启超级按钮中的"搜索"功能.当然,你也可以先召唤出超级按钮,然后选择其中的"搜索"功能.在搜索界面的下方有三个类型,分别是:应用.设置和文件.我们在右侧的搜索窗口输入想要搜索的内容名称或关键字,包涵它的所有应用.设置和文件都会在屏幕左侧显示. 应用商店中搜索应用 应用商店里有成千上万海量的应用,如果我们挨个查找,就有点太费时间了.别急,超级按钮中