《PHP實戰:Yii 2.0實現聯表查詢加搜索分頁的方法示例》要點:
本文介紹了PHP實戰:Yii 2.0實現聯表查詢加搜索分頁的方法示例,希望對您有用。如果有疑問,可以聯系我們。
相關主題:YII框架
PHP學習前言
PHP學習最近在學習yii2.0,在使用yii2.0過程中遇到一些問題,現將查詢搜索分頁的方法整理如下,分享出來供大家參考學習,話不多說,來一起看看詳細的介紹:
PHP學習主表:{{%article}}
PHP學習關聯表:{{%article_class}}
PHP學習方法如下
PHP學習1、使用gii創建CRUD和search不詳述
PHP學習2、在Article中添加的關聯內容,代碼#注釋部分
PHP學習
class Article extends \yii\db\ActiveRecord
{
#關聯查詢1:這里加上被關聯字段
public $class_name;
...
public function rules()
{
return [
[['article_title','article_content'], 'required'],
[['article_content','article_title','article_class'], 'string'],
[['article_addtime', 'article_updatetime'], 'integer'],
[['article_title', 'article_author'], 'string', 'max' => 50],
#關聯查詢2:這里加上safe驗證,表示該表單字段無驗證規則
['class_name','safe'],
];
}
...
#關聯查詢3:獲取被關聯表 mysite_article_class
public function getArticleClass(){
/**
* 第一個參數為要關聯的子表模型類名稱,
* 第二個參數指定通過子表的 id 去關聯主表的 article_class 字段
*/
return $this->hasMany(ArticleClass::className(), ['id' => 'article_class']);
}
...
}
PHP學習3、在ArticleSearch中添加的查詢和關聯內容,代碼#注釋部分
PHP學習
class ArticleSearch extends Article
{
#關聯查詢1:這里加上被關聯字段
public $class_name;
...
public function rules()
{
return [
[['id', 'article_addtime', 'article_updatetime'], 'integer'],
[['article_title', 'article_content', 'article_class', 'article_author'], 'safe'],
#關聯查詢2:這里加上safe驗證,表示該表單字段無驗證規則
['class_name','safe'],
];
}
...
public function search($params)
{
$query = Article::find();
// add conditions that should always apply here
#關聯查詢4:使用jionWith和select做關聯查詢
$query = Article::find();
$query->joinWith(['articleClass']);
$query->select("{{%article}}.*,{{%article_class}}.class_name");
$dataProvider = new ActiveDataProvider([
'query' => $query,
]);
$this->load($params);
if (!$this->validate()) {
return $dataProvider;
}
// grid filtering conditions
#精確查詢
$query->andFilterWhere([
'id' => $this->id,
'article_addtime' => $this->article_addtime,
'article_updatetime' => $this->article_updatetime,
#關聯查詢5:添加被關聯字段的精確查詢,這里要跟view表單被查詢屬性一致,
// '{{%article_class}}.class_name' => $this->class_name,
]);
#模糊查詢
$query->andFilterWhere(['like', 'article_title', $this->article_title])
->andFilterWhere(['like', 'article_content', $this->article_content])
->andFilterWhere(['like', 'article_class', $this->article_class])
->andFilterWhere(['like', 'article_author', $this->article_author])
#關聯查詢5:添加被關聯字段的精確查詢,這里要跟view表單被查詢屬性一致,
->andFilterWhere(['like', '{{%article_class}}.class_name', $this->class_name]);
return $dataProvider;
}
...
}
PHP學習4、在ArticleController中添加的分頁內容,代碼#注釋部分
PHP學習
public function actionIndex()
{
$article = new Article();
#查詢
$searchModel = new ArticleSearch();
$dataProvider = $searchModel->search(Yii::$app->request->queryParams);
#分頁
$dataProvider->pagination = ['pagesize' => '3'];
return $this->render('index', [
'dataProvider' => $dataProvider,
'model' => $article,
'searchModel' => $searchModel,
]);
}
PHP學習5、在index view中添加的表單內容,代碼#注釋部分
PHP學習
<?= GridView::widget([
'dataProvider' => $dataProvider,
#查詢表單
'filterModel' => $searchModel,
'columns' => [
[
'class' => 'yii\grid\SerialColumn',
'header' => '編號',
],
// 'article_class',
#注意這里被關聯表字段是{{%article_class}}.class_name,表單屬性這么寫'attribute' => 'class_name',
#查詢結果就是被關聯表字段值'value' => 'class_name',
[
'label'=>'文章分類',
'attribute' => 'class_name',
'value' => 'class_name',
],
'article_title',
'article_addtime:datetime',
// 'article_updatetime:datetime',
// 'article_author',
[
'class' => 'yii\grid\ActionColumn',
'header' => '操作',
],
],
]); ?>
PHP學習以上步驟完成結果如圖:
PHP學習
PHP學習總結
PHP學習以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對維易PHP的支持.
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/386.html