CakePHP3チュートリアルで日付と時刻のDateTimeでエラーが出たときの対処方法
2017/10/28
CakePHP3のチュートリアルの「ブックマークチュートリアル」のエラー
CakePHP3のチュートリアルの「ブックマークチュートリアル」
CakePHP3には、CakePHP3を使ってプログラムを開発する仕組みを理解するためのチュートリアルが用意されています。
その一つに「ブックマークチュートリアル」があります。
https://book.cakephp.org/3.0/ja/tutorials-and-examples/bookmarks/intro.html
そのチュートリアルを読みながら、その中にある「カスタム Finder メソッド」のリンクについて調べていました。
その際、「データの取り出しと結果セット」の「データのロードに Finder を使う」について調べている際、下記のコードがありました。
1 2 3 4 5 6 |
// コントローラやテーブルのメソッド内で $query = $articles->find('all', [ 'conditions' => ['Articles.created >' => new DateTime('-10 days')], 'contain' => ['Authors', 'Comments'], 'limit' => 10 ]); |
URLとしては下記になります。
https://book.cakephp.org/3.0/ja/orm/retrieving-data-and-resultsets.html#finder
実は、これをこのまま実行すると下記のエラーがでます。
1 |
Error: Class 'App\Controller\DateTime' not found |
「DateTime」がないということでしたので、下記の「日付と時刻」を調べ、
https://book.cakephp.org/3.0/ja/core-libraries/time.html
下記のクラスを呼び出す宣言を追加しました。
1 |
use Cake\I18n\Time; |
ですが、改善しませんでした。
CakePHP3では、namespace(名前空間)が使用されるようになりましたので、下記の様に記述をしても DateTimeがありません(’App\Controller\DateTime’ not found)のエラーが出るようになってしまっています。
1 |
$date = new DateTime('2017-05-05'); |
この対応をするためには「DateTime」の前に「\
」を編集して、下記の様にする必要があります。
1 |
$date = new \DateTime('2017-05-05'); |
CakePHP3のチュートリアルの「ブックマークチュートリアル」の場合は、先に表示したプログラムの 3行目を下記の様にする必要があります。
1 |
'conditions' => ['Articles.created >' => new \DateTime('-10 days')], |
もしくは、プログラムの最初に下記の宣言をする必要があります。
1 |
use \DateTime; |
ちなみに、下記のページには「new DateTime(‘2014-01-01’)」のような表記が 7ヵ所ありますが、正しく「\
」が編集されているのは 1ヵ所だけのようでした。
データの取り出しと結果セット
https://book.cakephp.org/3.0/ja/orm/retrieving-data-and-resultsets.html#finder
CakePHP3のドキュメントは整備されていないところもありますので、まだまだこれから、という感じでしょうか。
CakePHP3の関連記事
CakePHP4のCSS、JavaScript、画像のブラウザへのキャッシュをコントロールするCakePHP3でレコードを保存(追加、更新、Insert、Update)する複数の方法を紹介
CakePHP3でモデルなしフォームからCSVをアップロードしレコードを更新する方法解説
CakePHP3でPHP Simple HTML DOM Parserを使ってスクレイピングする方法
CakePHP3のInsert On Duplicate Key Update(upsert)構文を解説・バルク処理も
CakePHP3の1対多での連携を中間テーブルを使った多対多の連携に変更するときの手順
CakePHP3でデフォルトのソート条件を設定してユーザの選択肢たソート条件を有効にする方法
CakePHP3で Ajaxを使う方法の解説。3.6以降対応。Successとthenの両方を解説。
CakePHP3でパンくずの指定は HTMLヘルパーを使って指定する方法を解説
CakePHP3にOGPをfetch、asignを利用してテンプレートごとに指定する方法を解説
その他の「CakePHP3」に関する記事一覧
GoogleAdwords
GoogleAdwords
この記事が参考になったと思いましたらソーシャルメディアで共有していただけると嬉しいです!
関連記事
-
-
CakePHP3のCakeDC/Usersでログインユーザの所有レコードのみ更新、削除する権限管理の設定方法
CakePHP3のユーザ管理、ログイン認証プラグイン「CakeDC/Users」の権限管理を行う方法やアクセスできるコントローラー、アクションを設定、所有権を持つレコードのみ更新できる設定方法を解説。
-
-
CakePHP 2.x系 Viewでのコメントの記述方法など
CakePHPにおいて View、ctpファイルでコメントを記述する方法を解説。
-
-
CakePHP3のインストールでURL rewriting……のエラーが!その解決方法解説
CakePHP3をインストールしたら URL rewriting is not properly configured.のエラーが。原因は.htaccessが有効になっていないこと。httpd.confに設定を追加すればOK。
-
-
CakePHP 2.3で確認画面付きのお問い合わせフォームの作り方
CakePHPで確認画面付きのお問い合わせフォーム、メールフォームの作り方をサンプルを提示しながら解説。
-
-
CakePHP4系、5系でカラムを指定して値があるかないかのチェックする
CakePHP4、5で指定したカラムに特定の値に該当のレコードの有無をチェックするにはexists()を使う。単純にカラムを指定する方法から複数条件をand、orで探すこともできる。
-
-
CakePHP2の検索Plugin CakeDC/Searchで重複を省くgroup by(distinct)の実装方法
CakePHP2の検索プラグイン「CakeDC/Search」で、重複レコードを省くgroup by、distinctを使う方法についての解説。設定する場所はpaginatorの条件とするので、find()関数と同じ。
-
-
CakePHP3の1対多での連携を中間テーブルを使った多対多の連携に変更するときの手順
CakePHP3で「1対多」の連携を中間テーブルを利用した「多対多」の連携に変更するときの手順のまとめ。中間テーブルの設定やModelの変更などを間違いやすい箇所を指摘しながらの解説。
-
-
MySQL、CakePHP 2.3で「tinyint(1)」の Boolean型の動作を再確認
MySQL+CakePHPの環境で「tinyint(1)」を利用する際の動作を検証。「tinyint(1)」の Boolean型について CakePHPでは自動処理が実施されていることを確認しました。
-
-
CakePHP3のビューで受取ったテーブルのオブジェクトを連想配列に変換する方法
コントローラーからビューに送ったテーブルのオブジェクトを連想配列に変換し、ビューの中で自由に使えるようにするメソッド「toArray()」の解説。連想配列に変換できれば利用度アップ!
-
-
CakePHP4で定数の設定と呼び出し方法の解説(defineとConfigure)
CakePHP4で定数を設定、使用する方法を解説。定数定義はdefineとConfigureを使用する方法を解説。また、bootstrap.phpに直接記述する方法と別のファイルにする方法を解説。