2013-08-19 52 views
-1

我需要獲取數據列表時選擇user_id ..我的意思是當我選擇用戶ID 1我需要獲得所有數據字段與用戶ID 1 .. 我附上我的控制文件爲此 現在我在這個問題..我打,M在警予更新尚未給我的解決方案使用User_id從數據庫獲取數據

u能描述如何實施這個

控制&視圖文件,這裏是我的DB &控制研究文件

CREATE TABLE IF NOT EXISTS `offer_company` (
    `id` int(60) NOT NULL AUTO_INCREMENT, 
    `company_name` varchar(150) NOT NULL, 
    `contact_detail` text NOT NULL, 
    `User_id` int(10) NOT NULL, 
    `created` varchar(60) NOT NULL, 
    `modified` varchar(60) NOT NULL, 
    `Active` varchar(25) NOT NULL, 
    PRIMARY KEY (`id`), 
    KEY `User_id` (`User_id`) 
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=39 ; 

PHP代碼

<?php 

class OfferCompanyController extends Controller 
{ 
/** 
* @var string the default layout for the views. Defaults to '//layouts/column2', meaning 
* using two-column layout. See 'protected/views/layouts/column2.php'. 
*/ 
public $layout='//layouts/column2'; 

/** 
* @return array action filters 
*/ 
public function filters() 
{ 
    return array(
     'accessControl', // perform access control for CRUD operations 
     'postOnly + delete', // we only allow deletion via POST request 
    ); 
} 

/** 
* Specifies the access control rules. 
* This method is used by the 'accessControl' filter. 
* @return array access control rules 
*/ 
public function accessRules() 
{ 
    return array(
     array('allow', // allow all users to perform 'index' and 'view' actions 
      'actions'=>array('index','view'), 
      'users'=>array('*'), 
     ), 
     array('allow', // allow authenticated user to perform 'create' and 'update' actions 
      'actions'=>array('create','update'), 
      'users'=>array('@'), 
     ), 
     array('allow', // allow admin user to perform 'admin' and 'delete' actions 
      'actions'=>array('admin','delete'), 
      'users'=>array('admin'), 
     ), 
     array('deny', // deny all users 
      'users'=>array('*'), 
     ), 
    ); 
} 

/** 
* Displays a particular model. 
* @param integer $id the ID of the model to be displayed 
*/ 
public function actionView($id) 
{ 
    $this->render('view',array(
     'model'=>$this->loadModel($id), 
    )); 
} 

/** 
* Creates a new model. 
* If creation is successful, the browser will be redirected to the 'view' page. 
*/ 
public function actionCreate() 
{ 
    $model=new OfferCompany; 

    // Uncomment the following line if AJAX validation is needed 
    // $this->performAjaxValidation($model); 

    if(isset($_POST['OfferCompany'])) 
    { 
     $model->attributes=$_POST['OfferCompany']; 
     if($model->save()) 
      $this->redirect(array('view','id'=>$model->id)); 
    } 

    $this->render('create',array(
     'model'=>$model, 
    )); 
} 

/** 
* Updates a particular model. 
* If update is successful, the browser will be redirected to the 'view' page. 
* @param integer $id the ID of the model to be updated 
*/ 
public function actionUpdate($id) 
{ 
    $model=$this->loadModel($id); 

    // Uncomment the following line if AJAX validation is needed 
    // $this->performAjaxValidation($model); 

    if(isset($_POST['OfferCompany'])) 
    { 

     $model->User_id=Yii::app()->user->id; 
     $model->attributes=$_POST['OfferCompany']; 
     if($model->save()) 
      $this->redirect(array('view','id'=>$model->id)); 
    } 

    $this->render('update',array(
     'model'=>$model, 
    )); 
} 

/** 
* Deletes a particular model. 
* If deletion is successful, the browser will be redirected to the 'admin' page. 
* @param integer $id the ID of the model to be deleted 
*/ 
public function actionDelete($id) 
{ 
    $this->loadModel($id)->delete(); 

    // if AJAX request (triggered by deletion via admin grid view), we should not redirect the browser 
    if(!isset($_GET['ajax'])) 
     $this->redirect(isset($_POST['returnUrl']) ? $_POST['returnUrl'] : array('admin')); 
} 

/** 
* Lists all models. 
*/ 
public function actionIndex() 
{ 
    $model = new OfferCompany('search'); 
     $model->unsetAttributes(); // clear any default values 
     if (isset($_GET['OfferCompany'])) 
     $model->attributes = $_GET['OfferCompany']; 

     $this->render('index', array(
     'model' => $model, 
     )); 
       } 

/** 
* Manages all models. 
*/ 
public function actionAdmin() 
{ 
    $model=new OfferCompany('search'); 
    $model->unsetAttributes(); // clear any default values 
    if(isset($_GET['OfferCompany'])) 
     $model->attributes=$_GET['OfferCompany']; 

    $this->render('admin',array(
     'model'=>$model, 
    )); 
} 

/** 
* Returns the data model based on the primary key given in the GET variable. 
* If the data model is not found, an HTTP exception will be raised. 
* @param integer $id the ID of the model to be loaded 
* @return OfferCompany the loaded model 
* @throws CHttpException 
*/ 

/** 
* Performs the AJAX validation. 
* @param OfferCompany $model the model to be validated 
*/ 
protected function performAjaxValidation($model) 
{ 
    if(isset($_POST['ajax']) && $_POST['ajax']==='offer-company-form') 
    { 
     echo CActiveForm::validate($model); 
     Yii::app()->end(); 
    } 
} 

}

+0

究竟哪個部分讓你煩惱?你粘貼了你所有的代碼,你可以專注於失敗的部分,你不知道該怎麼做?另外,我建議看看這個:http://stackoverflow.com/questions/how-to-ask –

回答

2

這個代碼幫助您以當前用戶的user_id從你的表中的數據:

$user_id = Yii::app()->user->name;  
$var = Model_name::model()->findByAttributes(array("user_id" => $user_id); 

你可以像訪問字段的值:

$var->attributes['id']; 

即使在您的視圖中,您也可以使用它很容易,以foreach爲例。 祝你好運

+0

如果你有「任何」其他問題關於這只是問 – 2013-08-19 06:11:20