L'exemple de cet article décrit l'utilisation de Zend_Db_Table_Row dans le tutoriel Zend Framework. Partagez-le avec tout le monde pour référence, comme suit :
1. Introduction
Zend_Db_Table_Row est la passerelle de données de lignes de Zend Framework. De manière générale, vous ne pouvez pas instancier Zend_Db_Table_Row vous-même, mais en appelant Zend_Db_Table. ::find() ou Zend_Db_Table::fetchRow() renvoie Zend_Db_Table_Row comme données de résultat. Une fois que vous obtenez un objet Zend_Db_Table_Row, vous pouvez modifier la valeur de l'enregistrement (reflétée comme un attribut de classe) puis appeler la méthode save(). Enregistrez les modifications apportées à la table d'origine.
2. Récupérez un enregistrement
Tout d'abord, vous devez instancier une classe Zend_Db_Table.
<?php // 设置一个 adapter require_once 'Zend/Db.php'; $params = array ( 'host' => '127.0.0.1', 'username' => 'malory', 'password' => '******', 'dbname' => 'camelot' ); $db = Zend_Db::factory('PDO_MYSQL', $params); // 为所有的Zend_Db_Table对象设置默认adapter require_once 'Zend/Db/Table.php'; Zend_Db_Table::setDefaultAdapter($db); // 连接到数据库中的某一个表 class RoundTable extends Zend_Db_Table {} $table = new RoundTable(); ?>
Ensuite, utilisez Zend_Db_Table : find() et la clé primaire pour interroger, ou utilisez la méthode Zend_Db_Table::fetchRow() pour interroger.
Le résultat renvoyé est un objet Zend_Db_Table_Row, le nom d'attribut de l'objet est sous la forme de camelCaps correspondant au souligné nom de la table dans la base de données .
Par exemple, si le nom de la table est first_name, alors l'attribut modifié dans la classe est firstName.
<?php // 从表中取回的结果数据是一个Zend_Db_Table_Row对象 $row = $table->fetchRow('first_name = "Robin"'); // // $row现在是一个带有多种公有属性的Zend_Db_Table_Row对象 // that map to table columns: // // $row->id = '3' // $row->nobleTitle = 'Sir' // $row->firstName = 'Robin' // $row->favoriteColor = 'yellow' // ?>
Modifier les données
C'est le cas. très facile à modifier les données des lignes Choses : Il vous suffit de modifier les attributs de classe selon la méthode conventionnelle. Ensuite, appelez la méthode save() pour enregistrer les résultats modifiés dans la table de données
<?php // 连接到数据库中的表 class RoundTable extends Zend_Db_Table {} $table = new RoundTable(); // 从表中取回的结果数据是一个Zend_Db_Table_Row对象 $row = $table->fetchRow('first_name = "Robin"'); // // $row现在是一个带有多种公有属性的Zend_Db_Table_Row对象 // that map to table columns: // // $row->id = '3' // $row->nobleTitle = 'Sir' // $row->firstName = 'Robin' // $row->favoriteColor = 'yellow' // // 改变favorite color字段,并且将变动存储到数据表中. $row->favoriteColor = 'blue'; $row->save(); ?>
Cependant, vous ne pouvez pas modifier la valeur de la clé primaire. Si vous essayez d'effectuer une opération de changement, Zend_Db_Table_Row lèvera une exception.
<?php // 连接到数据库中的表 class RoundTable extends Zend_Db_Table {} $table = new RoundTable(); // fetch a record from the table as a Zend_Db_Table_Row object $row = $table->fetchRow('first_name = "Robin"'); // 我们尝试修改主键值 try { $row->id = 5; echo "We should not see this message, as an exception was thrown."; } catch (Zend_Db_Table_RowException $e) { echo $e->getMessage(); } ?>
J'espère que cet article sera utile à la programmation PHP de chacun basée sur Zend. Cadre-cadre.
Pour plus de didacticiels Zend Framework, d'analyses d'exemples d'utilisation de Zend_Db_Table_Row et d'articles connexes, veuillez faire attention au site Web PHP chinois !