gpt4 book ai didi

php - Yii - 如何在管理页面上按外键/相关键的列进行搜索?

转载 作者:行者123 更新时间:2023-12-02 05:11:48 26 4
gpt4 key购买 nike

在我的数据库中,我有两个表,制造商和塑料:

CREATE TABLE `manufacturer` (                                                                   
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(64) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=30 DEFAULT CHARSET=utf8

CREATE TABLE `plastic` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(64) NOT NULL DEFAULT '',
`manufacturer_id` int(11) NOT NULL DEFAULT '0',
PRIMARY KEY (`id`),
UNIQUE KEY `name` (`name`,`manufacturer_id`),
KEY `manufacturer_id` (`manufacturer_id`),
CONSTRAINT `plastic_ibfk_1` FOREIGN KEY (`manufacturer_id`) REFERENCES `manufacturer` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=68 DEFAULT CHARSET=utf8

如您所见,塑料具有 Yii 所说的与制造商的 BELONGS_TO 关系 - 一个制造商可以生产多种不同的塑料。

我正在尝试使从默认塑料管理页面按制造商名称搜索成为可能,但搜索字段没有显示制造商列。我关注了this guide我想我快到了,但我被困在一个小细节上。

在我的塑料模型课中,根据上面的链接,我有:

class Plastic extends CActiveRecord
{
public $manufacturer_search; //<-- added per the above link

public function rules()
{
return array(
array('manufacturer.name', 'length', 'max'=>64),
array('name', 'length', 'max'=>64),
array('name, manufacturer.name, manufacturer_search', 'safe', 'on'=>'search'),
);
}

public function relations()
{
return array(
'manufacturer' => array(self::BELONGS_TO, 'Manufacturer', 'manufacturer_id'),
);
}

public function search()
{
$criteria=new CDbCriteria;
$criteria->with=array('manufacturer');
$criteria->compare('name',$this->name,true);
$criteria->compare('manufacturer.name',$this->manufacturer_search, true);

return new CActiveDataProvider($this, array(
'criteria'=>$criteria,
));
}

管理页面使用 CGridView 小部件来显示所有内容(这是默认设置,除了 'columns' 属性我没有更改任何内容):

<?php $this->widget('zii.widgets.grid.CGridView', array(
'id'=>'plastic-grid',
'dataProvider'=>$model->search(),
'filter'=>$model,
'columns'=>array(
'name',
'manufacturer.name',
array(
'class'=>'CButtonColumn',
),
),
)); ?>

令人抓狂的是搜索确实有效:如果我点击高级搜索,然后在制造商字段中输入一些内容,就可以了。但我终究无法让搜索框显示在 GridView 中。

Here是一些截图:当我将 manufacturer_id 传递到小部件时的管理页面截图,当我像上面的代码一样传递 manufacturer.name 时的截图,当我通过 manufacturer_search 时的截图(我没想到它会起作用),最后是高级搜索正常工作的屏幕截图。

有什么想法吗?谢谢。

最佳答案

您必须专门为 $manufacturer_search 创建一个过滤器,例如:

<?php $this->widget('zii.widgets.grid.CGridView', array(
'id'=>'plastic-grid',
'dataProvider'=>$model->search(),
'filter'=>$model,
'columns'=>array(
'name',
array(
'name'=>'manufacturer.name',
'filter'=>CHtml::activeTextField($model,'manufacturer_search'),
),
array(
'class'=>'CButtonColumn',
),
),
)); ?>

关于php - Yii - 如何在管理页面上按外键/相关键的列进行搜索?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15320592/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com