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

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

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

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

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

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

Q&A

解決済

1回答

762閲覧

Laravel where句について

KinD

総合スコア28

MySQL

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

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

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

0グッド

0クリップ

投稿2021/06/13 08:09

編集2021/06/13 08:10

こんにちは。
教えてください。laravel8(PHP7.4.20)を使用しています。

ユーザが投稿したデータをpostテーブルに保存しており、
①の処理で投稿したデータを取得することはできました。
ここから、投稿したユーザの名前を取得したいのですが、
where句にどのように指定すれば良いのかがわかりません。

①最新の投稿10件を取得

Laravel

1$recent_posts = Post::where('grand_status', 1)->orderBy('id', 'DESC')->limit(10)->with('user')->has('user')->get();

② ①で取得した10件の投稿に対して、投稿したユーザ名を取得したいです

Laravel

1 2→これだとUserテーブル全件取得できた 3$users = User::orderBy('id', 'DESC')->get(); 4 5→これだとUserテーブルのid=3のユーザのデータが取得できた 6$users = User::where('id', 3)->orderBy('id', 'DESC')->get(); 7 8→なので、引数に①で取得したデータからidを抜き出せば良いかと考えたのですがエラーになりました。 9$users = User::where('id', $recent_posts->id)->orderBy('id', 'DESC')->get(); 10

SQLは結合?するのが良いのかと思ったのですが、方法がわからなかったので
順番に取得する方法で試してみました。
このような場合、どのようにすれば取得することができるのでしょうか。

テーブル構成は下記のようにしています

MSQL

1 2mysql> DESCRIBE posts; 3+----------------+-----------------+------+-----+---------+----------------+ 4| Field | Type | Null | Key | Default | Extra | 5+----------------+-----------------+------+-----+---------+----------------+ 6| id | bigint unsigned | NO | PRI | NULL | auto_increment | 7| user_id | bigint unsigned | NO | MUL | NULL | | 8| photo_url | varchar(191) | YES | | NULL | | 9| comment | text | YES | | NULL | | 10| likes | int | NO | | 0 | | 11| grand_status | tinyint(1) | NO | | 0 | | 12| post_status | tinyint(1) | NO | | 0 | | 13| created_at | timestamp | YES | | NULL | | 14| updated_at | timestamp | YES | | NULL | | 15+----------------+-----------------+------+-----+---------+----------------+ 16 17 18mysql> DESCRIBE users; 19+--------------------------------+-----------------+------+-----+---------+----------------+ 20| Field | Type | Null | Key | Default | Extra | 21+--------------------------------+-----------------+------+-----+---------+----------------+ 22| id | bigint unsigned | NO | PRI | NULL | auto_increment | 23| name | varchar(191) | YES | | NULL | | 24| points | bigint | NO | | 0 | | 25| created_at | timestamp | YES | | NULL | | 26| updated_at | timestamp | YES | | NULL | | 27| deleted_at | timestamp | YES | | NULL | | 28+--------------------------------+-----------------+------+-----+---------+----------------+ 29

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

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

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

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

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

m.ts10806

2021/06/13 08:32

クエリビルダではなくSQLで書けますか? フレームワーク使うからにはPHPもそうですし、SQLもそれなりに書けないと宝の持ち腐れになります。 特にLaravelは「Web職人のためのフレームワーク」という謳い文句があるくらい、学習コストは高いです。
KinD

2021/06/13 09:02

ありがとうございます。 お指摘いただき、無理してクエリビルダを使わなくても直接SQLかけることに気づきました。 下記の書き方でも無事することができました。 $users = DB::select("SELECT p.id,u.name from posts p ,users u where p. user_id =u.id and p. grand_status=1 order by p. id desc limit 10"); dd($users);
m.ts10806

2021/06/13 09:14

直書きは悪手かと
guest

回答1

0

ベストアンサー

php

1$recent_posts = Post::where('grand_status', 1)->orderBy('id', 'DESC')->limit(10)->with('user')->has('user')->get(); 2

blade

1@foreach ($recent_posts as $post) 2<p>{{ $post->user->name }}</p> 3@endforeach

投稿2021/06/13 08:56

phper.k

総合スコア3923

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

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

KinD

2021/06/13 09:03

クエリビルダでの取得方法が知りたかったので、とても勉強になりました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問