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

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

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

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

1回答

1455閲覧

[Laravel5.4]EloquentでのIDの割り振り、ミューテーターの実行結果の仕様が知りたい

退会済みユーザー

退会済みユーザー

総合スコア0

PHP

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2017/09/02 11:29

編集2017/09/02 11:58

Lara帳
こちらの記事を参考にしています。

php artisan tinker後に、Eloquentを実行していました。
自身が実行しているときに、

>>> App\Article::all()->toArray(); => [ [ "id" => 1, "title" => "hajimetenotitle", "body" => "kakukakushikajika", "created_at" => "2017-09-02 12:50:37", "updated_at" => "2017-09-02 12:50:37", "published_at" => "2017-09-02 12:49:24", ], [ "id" => 3, "title" => "nikennmenokiji", "body" => "hogehoge", "created_at" => "2017-09-02 20:01:38", "updated_at" => "2017-09-02 20:01:38", "published_at" => "2017-09-02 20:01:27", ], [ "id" => 4, "title" => "sannkennmenokiji", "body" => "wagahaihanekodearu", "created_at" => "2017-09-02 20:08:54", "updated_at" => "2017-09-02 20:08:54", "published_at" => "2017-09-02 20:08:54", ], ]

という結果になりました。
(コマンドプロンプト上で全角入力できなかったのでローマ字になってしまいました、読みづらくて申し訳ないです)
Lara帳での見本を見てみると、削除したID(2)のところは詰められて、sannkennmenokiji にID(2)が割り振られていました。
ですが、私自身の環境では2に詰められず4が割り振られました。

また、ミューテーター各種の実行結果の確認をしていたら、

>>> $article = App\Article::first(); => App\Article {#711 id: "1", title: "hajimetenotitle", body: "kakukakushikajika", created_at: "2017-09-02 12:50:37", updated_at: "2017-09-02 12:50:37", published_at: "2017-09-02 12:49:24", } >>> $article->published_at => "2017-09-02 12:49:24"

$article = App\Article::first();
の見本ではタイムゾーンが取り出されているところがそうならず、
title/bodyや作成時間・更新時間などが更新されたりしています。
$article->published_at
の部分では日時のみが表示されています。

同じように入力してたつもりなのですが、何か失敗したのでしょうか。
仕様変更等があったのならそれでひとまず納得するのですが・・・。
この事についてご存じの方、ご教示ください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

IDはデータベースのオートインクリメントという働きにより自動的にオートインクリメント値に1ずつ増分したものが順次採番されます。よって2が割り振られる事は保存時にID値を入力するか、オートインクリメント値を修正しない限り無いです。
MySLQ 3.6.9 AUTO_INCREMENT の使用
SQLite Autoincrement

タイムゾーンが取り出されているというのは、多分Carbon型のダンプ結果かと思うので、published_atをCarbonインスタンスに変換したい場合は、日付ミューテタとして、Modelクラスのprotected $datesにpublished_atを入れるとできるかと思います。
ドキュメントの日付ミューテタを参考にしてください。
Laravel 5.4 Eloquent:ミューテタ

投稿2017/09/02 12:38

編集2017/09/02 12:40
aro10

総合スコア4106

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

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

退会済みユーザー

退会済みユーザー

2017/09/03 02:24

ありがとうございます!双方ともに正常だったのですね。 一つ前の質問でもそうでしたが、参考URLに英文のみのものがありました。 aro10さんは自己翻訳していらっしゃいますか?
aro10

2017/09/03 05:02

ブラウザの翻訳アドオンなども併用して単語などは翻訳しながらみています。
退会済みユーザー

退会済みユーザー

2017/09/03 12:57

ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問