Search 如何更改搜索模型以使用一个字段
我有积垢生成的bu Gii。默认情况下,应用程序中的搜索为每个表列使用一个字段。我应该如何更改搜索模式,以便通过单独字段在所有列中进行搜索 这是我的模型:Search 如何更改搜索模型以使用一个字段,search,crud,yii2,Search,Crud,Yii2,我有积垢生成的bu Gii。默认情况下,应用程序中的搜索为每个表列使用一个字段。我应该如何更改搜索模式,以便通过单独字段在所有列中进行搜索 这是我的模型: class UserSearch extends User { /** * @inheritdoc */ public function rules() { return [ [['id', 'status', 'created_at', 'updated_a
class UserSearch extends User
{
/**
* @inheritdoc
*/
public function rules()
{
return [
[['id', 'status', 'created_at', 'updated_at'], 'integer'],
[['username', 'auth_key', 'password_hash', 'password_reset_token', 'email'], 'safe'],
];
}
/**
* @inheritdoc
*/
public function scenarios()
{
// bypass scenarios() implementation in the parent class
return Model::scenarios();
}
/**
* Creates data provider instance with search query applied
*
* @param array $params
*
* @return ActiveDataProvider
*/
public function search($params)
{
$query = User::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->andFilterWhere([
'id' => $this->id,
'status' => $this->status,
'created_at' => $this->created_at,
'updated_at' => $this->updated_at,
]);
$query->andFilterWhere(['like', 'username', $this->username])
->andFilterWhere(['like', 'auth_key', $this->auth_key])
->andFilterWhere(['like', 'password_hash', $this->password_hash])
->andFilterWhere(['like', 'password_reset_token', $this->password_reset_token])
->andFilterWhere(['like', 'email', $this->email]);
return $dataProvider;
}
}
我就是这样做的:
public function search($params)
{
..............................
if($this->keyword) {
if(preg_match("/[A-Za-z]+/", $this->keyword) == true) {
$query->andFilterWhere(['like', 'LOWER(CONCAT(name, age, WHATEVERFIELDS)), ', strtolower($this->keyword)]);
} else {
$query->andFilterWhere(['id' => $this->keyword]);
}
}
关键字实际上不是数据库中的一列,它只是我附加到搜索模型的一个变量。如果关键字是数字的,我认为它是ID,如果你想,你可以忽略这个部分。否则,我将搜索一些字段并搜索结果。您也可以不在字段中添加条件,只为每个字段添加一个条件,这取决于您自己
您可以在以下位置查看完整文件:如果尝试
$query->andFilterWhere(['id'=>$this->keyword,'price'=>$this->keyword,]),我希望添加更多选项代码>但是在这种情况下,搜索被中断,只能使用“/[A-Za-z]+/”
你能帮我吗?