Another yii - Trying to get property of non-object - php

sory another yii question, try this bust seems doesnt works.
I have this error, still learning yii
Trying to get property of non-object
D:\xampp\htdocs\mou\protected\views\mou\view.php(26)
Did i miss something? thanks before.
D:\xampp\htdocs\mou\protected\views\mou\view.php(26)
14 'value'=>Yii::app()->dateFormatter->format('dd/MM/yyyy',$model->tgl_perjanjian),
15 ),
16 array(
17 'name'=>'tgl_awal',
18 'value'=>Yii::app()->dateFormatter->format('dd/MM/yyyy',$model->tgl_awal),
19 ),
20 array(
21 'name'=>'tgl_akhir',
22 'value'=>Yii::app()->dateFormatter->format('dd/MM/yyyy',$model->tgl_akhir),
23 ),
24 array(
25 'name'=>'Mitra KY',
26 'value'=>$model->mitra_mous->mitra->nama,
27 ),
28 'lingkup_kerjasama',
29 'penandatangan',
30 'jabatan_penandatangan',
31 array(
32 'name'=>'file',
33 'type'=>'raw',
34 'value'=>CHtml::link($model->file,Yii::app()->baseUrl . '/files/mou/' .$model->file),
35 ),
36 ),
37 )); ?>
this is my models Mitra.php
public function relations()
{
// NOTE: you may need to adjust the relation name and the related
// class name for the relations automatically generated below.
return array(
'jenis0' => array(self::BELONGS_TO, 'JenisMitra', 'jenis'),
'kab0' => array(self::BELONGS_TO, 'Wilayah', 'kab'),
'prov0' => array(self::BELONGS_TO, 'Wilayah', 'prov'),
'mitra_mous' => array(self::HAS_MANY, 'MitraMou', 'mitra_id'),
);
}
and this is models Mou.php
public function relations()
{
// NOTE: you may need to adjust the relation name and the related
// class name for the relations automatically generated below.
return array(
'mitra_mous' => array(self::HAS_MANY, 'MitraMou', 'mou_id'),
'mitras' => array(self::HAS_MANY, 'Mitra', 'mitra_id','through'=>'mitra_mous'),
);
}

Change your line 26 to the code below.
use this code below
'value'=>$model->mitras->nama,

It seems that your mitra_mous relation is the problem. Due to the fact that the relation is a one-to-many relation, $model->mitra_mous will return an array. You cannot try to get a property from an array, so $model->mitra_mous->mitra is invalid. Maybe you can reference only one of the items of the array, say $model->mitra_mous[0]->mitra->nama.
I am not sure if this solves your issue, but at least that line should work.
Be careful with this solution anyway, because if $model->mitra_mous has no elements, the code will fail. Yo may have to add a condition for that case.
Hope I have helped.
Good luck!

Related

Yii Relation Has_Many Filtering

I currently have 2 db tables, one containing a list of shows and one containing times these shows are on.
So I have a HAS_MANY relationship between the two.
I have successfully managed to pull out the films and the times associated to them via the HAS_MANY relationship.
The section I am struggling with is I want to show the first 10 films that have times against them (some do not). The code below pulls out just the first 10 irrelevant of whether they have times against them:
$films=filmrecord::model()
->findAll(array(
'order' => 'priority',
'limit' => 10
));
foreach ($films as $thefilm) {
array_push($filmListings, array(
'id' => $thefilm->id,
'title' => $thefilm->title,
'url' => $thefilm->url,
'poster_url' => $thefilm->p_url,
'times' => $thefilm->filmtimes
));
}
return filmListings;
The HAS_MANY relationship I am using is:
'filmtimes' => array(self::HAS_MANY, 'FilmsTimesRecord', 'film_id')
I know I could simply put in a if statement to check if $thefilm->filmtimes was set however ideally I would like to check at an db point to avoid having to pull all films out before checking.
Is there any way I can the existence of a relationship within the findAll?
Any pointers would be much appreciated.
Regards
wizzer
please try this solution for find all film with film times records using has_many relationship.
'filmtimes' => array(self::HAS_MANY, 'FilmsTimesRecord', 'film_id')
$films=filmrecord::model()->with('filmtimes')->findAll(array('order' => 'priority','limit' => 10));

yii join table using relations deploy to Linux not work

I using curd to show CGridview I join 2 table in my computer it work
but when deploy to linux server not work what wrong? ,help me pls!!
in controller
myController
$model=new UserLogin('search');
$model->unsetAttributes();
$dataProvider = new CActiveDataProvider('UserLogin', array(
'criteria' => array(
'with'=>'group',
),
'pagination' => array(
'pageSize' => 20,
),
));
$this->render('admin', array(
'dataProvider'=>$dataProvider,'model'=>$model)
);
this error
Invalid argument supplied for foreach()
/data/home/nueng/www/html/framework/db/ar/CActiveFinder.php(466)
454
455 /**
456 * Performs lazy find with the specified base record.
457 * #param CActiveRecord $baseRecord the active record whose related object is to be fetched.
458 */
459 public function lazyFind($baseRecord)
460 {
461 if(is_string($this->_table->primaryKey))
462 $this->records[$baseRecord->{$this->_table->primaryKey}]=$baseRecord;
463 else
464 {
465 $pk=array();
466 foreach($this->_table->primaryKey as $name)
467 $pk[$name]=$baseRecord->$name;
468 $this->records[serialize($pk)]=$baseRecord;
469 }
470
Hum just a guess are you respecting the case in the model name group in your with criteria?
Linux is case sensitive so if you put group instead of Group in your relation name or in the model name of the relation an error could occur.

cakephp 2.2 Acl not working(groups)

im going through http://book.cakephp.org/2.0/en/tutorials-and-examples/simple-acl-controlled-application/simple-acl-controlled-application.html <--- this tutorial and guess what? ;) it doesnt work, im Using cakephp 2.2.2... i get next error
Undefined index: id [CORE/Cake/Model/AclNode.php, line 140]
AclNode::node() - Couldn't find Aro node identified by
"Array ( [Aro0.model] => User [Aro0.foreign_key] => )
" Error: An Internal Error Has Occurred.
this error is becouse i dont get my group_id in my User model
public function bindNode($user) {
return array('model' => 'Groups', 'foreign_key' => $user['Users']['groups_id']);
}
So in this function $user var contains only username and password... and no group_id's
Please help guys...
Model name must be singular.
'model' => 'Group'
$user['Users']['group_id'] //in your DB, put "group_id" to, not "groups_id"
Make sure that the Model you've created is "Group". :)
I've just encountered this problem. Tracing the code back the issue was that my model was called 'AdminUser' and not the default, 'User'. Altering the userModel setting solved it for me.
public $components = array(
'Acl',
'Auth' => array(
'authorize' => array(
'Actions' => array(
'actionPath' => 'controllers',
'userModel' => 'AdminUser'
)
)
),
'Session'
);
Looking at your bindNode method it looks like your using a model named 'Users' rather than 'User' so setting the userModel to 'Users' might do the trick.
I hope that helps,
Pete

SQL JOINs with CakePHP

I have an images table and a servers table. images has a server_id field which is a foreign key to the id field in the servers table. The servers table also has a field called name, which is what I want to retrieve.
Here's my controller action code:
$images = $this->Image->find('all', array(
'conditions' => array('Image.user_id' => $this->Auth->user('id')),
'order' => array('Image.uploaded DESC')
));
$this->set('images', $images);
It gets data like this:
Array
(
[0] => Array
(
[Image] => Array
(
[id] => 103
[orig_name] => Untitled-5.jpg
[hash] => MnfWKk
[filename] => MnfWKk.jpg
[uploaded] => 2012-07-12 00:09:08
[views] => 0
[album_id] =>
[user_id] => 15
[server_id] => 1
)
)
)
Instead of server_id, I want to get the name field from the servers table. How can I adapt my find() method to get this? I know it's an SQL join, but I have no idea how to tell Cake to do one in order to get the servers name.
Thanks.
TLDR:
Set up the correct CakePHP associations, and use CakePHP's Containable. (with recursive -1).
Longer Description:
It's best practice to keep your find code in the model itself, so that's what I'll show, but feel free (if you must) to move it back into the controller.
Doing it this way allows you to call the same getImages() function from any controller, and just pass different parameters based on what you want returned. The benefit to coding like this is, you always know if you're looking for code related to queries/database, that you should be looking in the model. It's VERY beneficial when the next person who looks at your code doesn't have to go searching.
Because of the association set up between Image and Server, you can then "contain" the Server info when you query images. But - you can't use "contain" until you specify that you want your model to $actAs = array('Containable');. [ CakePHP Book: Containable ]
Lastly, in your AppModel, it's good practice to set $recursive = -1;. That makes it default to -1 for all models. If for some reason you're against doing that, just make sure to set recursive to -1 any time you use containable. And - once you learn to use containable, you'll never look back - it's awesome. There are a lot more things you can
Code:
//AppModel *******
//...
$recursive = -1;
//...
//Images controller *******
//...
public function whatever() {
$opts = array();
$opts['user'] = $this->Auth->user('id');
$images = $this->Image->getImages($opts);
$this->set(compact('images'));
}
//...
//Image model *******
//...
public $actsAs = array('Containable');
public belongsTo = array('Server');
public function getImages($opts = array()) {
$params = array('condtions'=>array());
//specific user
if(!empty($opts['user'])) {
array_push($params['conditions'], array('Image.user_id'=>$opts['user']);
}
//order
$params['order'] = 'Image.uploaded DESC';
if(!empty($opts['order'])) {
$params['opts'] = $opts['order'];
}
//contain
$params['contain'] = array('Server');
//returns the data to the controller
return $this->find('all', $params);
}
A few other notes
You should also set the association in your Server model.
The code example I gave is written fairly verbosely (is that a word?). Feel free to condense as you see fit
You can also extend the model's getImages() method to accept a lot more parameters like find, limit...etc. Customize this all you want - it's not THE way to do it - just similar to what I usually use.
Per your question, if you only need one field, you can specify in the "contain" what fields you want - see the book for details.
It might seem confusing now, but it's SOO worth learning how to do this stuff right - it will make your life easier.
Cake have a lot of model relationships to achieve this. Check out this page, I think you'll be using the belongsTo relationship
Easy and alternate way for begginers
$images = $this->Image->find('all', array(
'conditions' => array('Image.user_id' => $this->Auth->user('id')),
'joins' => array(
array(
'table' => 'servers',
'alias' => 'Server',
'type' => 'inner', //join of your choice left, right, or inner
'foreignKey' => true,
'conditions' => array('Image.server_id=Server.id')
),
),
'order' => array('Image.uploaded DESC')
));
This is very good in performance

CActiveDataProvider not resolving params in criteria

I'm following along with Agile Web Application Development with Yii 1.1 and PHP5, working on the "TrackStar" project. For the life of me I can't understand where my problem is.
I'm getting the Exception:
CDbCommand failed to execute the SQL statement: SQLSTATE[HY093]: Invalid parameter number: parameter was not defined. The SQL statement executed was: SELECT COUNT(*) FROM tbl_issue t WHERE project_id=:projectId
It appears (to this noob's interpretation) that the params in my CActiveDataProvider is some how not resolving in the criteria as in the view:
(in /protected/controllers/ProjectController.php)
55 public function actionView()
56 {
57 $issueDataProvider = new CActiveDataProvider('Issue', array(
58 'criteria' => array(
59 'condition' => 'project_id=:projectId',
60 'params' => array(':projectId=' => $this->loadModel()->id),
61 ),
62 'pagination' => array(
63 'pageSize' => 1,
64 ),
65 ));
66 $this->render('view',array(
67 'model'=>$this->loadModel(),
68 'issueDataProvider' => $issueDataProvider,
69 ));
70 }
I checked my code against a github repo and I couldn't find any differences anywhere.
Is there something straightforward I'm missing here without having to post all of my code (and have somebody actually look through it)?
It looks you have an error in params of your criteria. (= after :projectId).
Right statement is
'params' => array(':projectId' => $this->loadModel()->id),
Params array is list of query parameter values indexed by parameter placeholders. For example, array(':name'=>'Dan', ':age'=>'31').

Categories