質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

2012閲覧

CakePHP2:テーブルモデルの共有は可能?

squirrel

総合スコア18

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

0クリップ

投稿2017/01/19 07:43

編集2017/01/19 07:44

接頭辞のみが異なる、まったく同じテーブル構成のテーブル[接頭辞]_applesがあります。
これらのテーブルで同じテーブルモデルの共有は可能でしょうか?

現在、以下のように設定して、コンストラクトの際にテーブル名を指定しているのですが、

php

1class Apple extends AppModel 2{ 3 public $useTable = false; 4 5 public function __construct($tableName) 6 { 7 $this->useTable = $tableName; 8 } 9}

findやsaveといった、cake既存のメソッドが使えず、
[The eventKey variable is required]のエラーが出てしまっている状態です。
因みに$this->getDataSource()->getLog();でもログは出力されておらず、

php

1$this->Apple->set($this->data['Apple']); 2$this->Apple->save();

をtry&catchしても何も捕獲されません。
よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kunai

2017/01/19 07:48

素直に別Modelを作る弊害があるのであれば教えてください。
squirrel

2017/01/19 08:31

動的に接頭辞が変わる想定です
popobot

2017/01/19 08:55

モデルはどうやってnewしているのでしょうか?
squirrel

2017/01/20 02:18

別モデルの中で普通にApp::uses('Apple', 'Model');して、$this->Apple= new Apple('abcd_apples');してます
guest

回答1

0

ベストアンサー

なんか面白そうだったのでやってみました。
ちなみにこちらの実行環境は、Nginx 10.0.2 / PHP 7.1.0 / CakePHP 2.8.9 / MySQL 5.7.17 となっています。

結論から言うと、parent::__construct();が足りないだけだと思います。

モデル:Apple.php

PHP

1<?php 2App::uses('AppModel', 'Model'); 3class Apple extends AppModel { 4 public $useTable = 'Apple'; 5 6 public function __construct($tableName) { 7 $this->useTable = $tableName; 8 //ココが肝心 useTableを入れ替えてからAppModel(親クラス)のコンストラクタをコールする 9 parent::__construct($tableName); 10 } 11}

コントローラ:AppleController.php

php

1class AppleController extends AppController { 2 public function AppleTest() { 3 $this->autoLayout = false; 4 $this->autoRender = false; 5 6 //Controllerの$uses配列に入れるとテーブル名の差し替えが出来ないので、個別にインスタンスを作る。その為の読み込み 7 App::uses('Apple', 'Model'); 8 //インスタンス化。ここでインスタンス化するテーブル名を指定 9 $this->Apple = new Apple('a1_apple'); 10 11 echo 'a1_apple: '; 12 //find all した結果を出力してみる 13 echo var_export($this->Apple->find('all'), true).'<br>'.PHP_EOL; 14 //getLogも見てみる 15 echo var_export($this->Apple->getDataSource()->getLog(), true).'<br>'.PHP_EOL; 16 17 18 //インスタンスを別テーブルに切り替え 19 $this->Apple = new Apple('a2_apple'); 20 21 echo 'a2_apple: '; 22 echo var_export($this->Apple->find('all'), true).'<br>'.PHP_EOL; 23 echo var_export($this->Apple->getDataSource()->getLog(), true).'<br>'.PHP_EOL; 24 } 25}

データ:a1_apple

idname
1a1_1
2a1_2

データ:a2_apple

idname
1a2_1
2a2_2
3a2_3
4a2_4

こちらで実行すると、以下のような出力となりました。

txt

1a1_apple: array ( 2 0 => array ( 3 'apple' => array ( 4 'id' => '1', 5 'name' => 'a1_1', 6 ), 7 ), 8 1 => array ( 9 'apple' => array ( 10 'id' => '2', 11 'name' => 'a1_2', 12 ), 13 ), 14) 15array ( 16 'log' => array ( 17 0 => array ( 18 'query' => 'SELECT `apple`.`id`, `apple`.`name` FROM `ca`.`a1_apple` AS `apple` WHERE 1 = 1', 19 'params' => array ( ), 20 'affected' => 2, 21 'numRows' => 2, 22 'took' => 0.0, 23 ), 24 ), 25 'count' => 1, 26 'time' => 0.0, 27) 28 29a2_apple: array ( 30 0 => array ( 31 'apple' => array ( 32 'id' => '1', 33 'name' => 'a2_1', 34 ), 35 ), 36 1 => array ( 37 'apple' => array ( 38 'id' => '2', 39 'name' => 'a2_2', 40 ), 41 ), 42 2 => array ( 43 'apple' => array ( 44 'id' => '3', 45 'name' => 'a2_3', 46 ), 47 ), 48 3 => array ( 49 'apple' => array ( 50 'id' => '4', 51 'name' => 'a2_4', 52 ), 53 ), 54) 55array ( 56 'log' => array ( 57 0 => array ( 58 'query' => 'SELECT `apple`.`id`, `apple`.`name` FROM `ca`.`a2_apple` AS `apple` WHERE 1 = 1', 59 'params' => array ( ), 60 'affected' => 4, 61 'numRows' => 4, 62 'took' => 0.0, 63 ), 64 ), 65 'count' => 2, 66 'time' => 0.0, 67)

コツとしては、Modelの__constructにて、parent::__construct();を行う前に$this->useTable = $tableName;を行う事ですかね。
こうする事で、書き換わったuseTableを使って、親クラスであるAppModelのコンストラクタを動かす事が出来ます。

投稿2017/01/19 09:25

編集2017/01/20 02:05
kunai

総合スコア5405

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

squirrel

2017/01/20 02:19

今までのがなんだったのかというくらいさっくり解決しました。ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問