2010-12-06 6 views
2

Je suis d'idées ici est mon contrôleur:Enregistrement tableau à base de données dans CakePHP

class GoogleNewsController extends AppController { 
    var $name = 'GoogleNews'; 
    var $uses = array('GoogleNews', 'SavedNews'); 
    var $helpers = array('Html','Form'); 
    function index() { 

$saved = $this->set('news',$this->GoogleNews->find('all')); 

données de lecture Im de « GoogleNews » et ils sont dans mon tableau. Tableau ressemble à ceci:

array(10) { 
    [0]=> 
    array(1) { 
    ["GoogleNews"]=> 
    array(12) { 
     ["title"]=> 
     string(32) "FIFA 11 für 25,49€ aus Jersey" 
     ["link"]=> 
     string(54) "http://feedproxy.google.com/~r/myDealZ/~3/HuNxRhQJraQ/" 
     ["pubDate"]=> 
     string(31) "Mon, 06 Dec 2010 10:53:22 +0000" 
     ["creator"]=> 
     string(5) "admin" 
     ["guid"]=> 
     array(2) { 
     ["value"]=> 
    string(30) "http://www.mydealz.de/?p=15137" 
    ["isPermaLink"]=> 
    string(5) "false" 
    } 
    ["description"]=> 
    string(355) " 

Et je veux sauver des éléments à ma base de données 'SavedNews de que je dois enregistrer la description et le titre. Quelqu'un peut-il me dire comment dois-je l'écrire?

$this->SavedNews->set(array('description' =>$this->GoogleNews->find('description'))); 

Est-ce une solution? Son seul moyen que cela fonctionne, mais il met des valeurs nulles à mes colonnes.

Répondre

4

Si je comprends bien vos besoins, ce qui suit devrait fonctionner.

Dans votre contrôleur:

class NewsController extends AppController 
{ 
    function import_from_google() 
    { 
     // Load the GoogleNews model and retrieve a set of its records 
     $this->loadModel('GoogleNews'); 
     $newsFromGoogle = $this->GoogleNews->find('all'); 

     $this->loadModel('SavedNews'); 
     foreach ($newsFromGoogle as $_one) { 

      // Reset the SavedNews model in preparation for an iterated save 
      $this->SavedNews->create(); 

      // Assemble an array of input data appropriate for Model::save() 
      // from the current GoogleNews row 
      $saveable = array(
       'SavedNews' => array(
       'title' => $_one['GoogleNews']['title'], 
       'description' => $_one['GoogleNews']['description'] 
      ) 
      ); 

      // send the array off to the model to be saved 
      $this->SavedNews->save($saveable); 
     } 

     $this->autoRender = false; // No need to render a view 
    } 
} 

Affiner comme souhaité/requis. Par exemple, les opérations de sauvegarde itérées doivent se produire dans le modèle SavedNews plutôt que dans le contrôleur. Le code ci-dessus n'a pas non plus de tolérance de panne.

HTH.

+0

Merci beaucoup, maintenant je comprends, c'était très utile – Jasiufila

Questions connexes