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

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

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

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

PHP

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

Q&A

解決済

2回答

1825閲覧

laraveのModelのorderbyで、新着1週間以内かつ更新順に並べる

chikarawazaman

総合スコア2

Laravel

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

PHP

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

0グッド

0クリップ

投稿2020/10/14 09:07

前提・実現したいこと

laravelを勉強中です。
Orderbyについて、下記のような条件は実現可能でしょうか。

・updated_at順に並べる
・created_atから一週間以内を上位に表示する

例:テーブルデータ

idcreated_atupdated_at
12020/10/012020/10/14
22020/10/022020/10/02
32020/10/032020/10/12
42020/10/042020/10/13
52020/10/052020/10/10
62020/10/102020/10/10
72020/10/112020/10/11
82020/10/122020/10/14
92020/10/132020/10/14

現在を2020/10/14とすると

idcreated_atupdated_at
82020/10/122020/10/14
92020/10/132020/10/14
72020/10/112020/10/11
62020/10/102020/10/10
12020/10/012020/10/14
42020/10/042020/10/13
32020/10/032020/10/12
52020/10/052020/10/10
22020/10/022020/10/02

こんな感じに、10/7以降の作成物を上にしたいです。

試したこと

ざっといろいろなWebページを見たのですが、
いろいろ理解が追い付いていないのかわかっておりません。

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

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

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

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

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

guest

回答2

0

ベストアンサー

実装的には、以下のようにSQLのIF文を使えばできるかと思います。
こういうことでしょうか?

しかし、読みやすいコードという意味では、
対象のリストを取得し、
対象外のリストを再度取得して後ろにくっつけるほうが、シンプルで良いかなと思います。

php

1Model::query() 2 ->select( 3 'created_at', 4 'updated_at', 5 DB::raw('IF(created_at > NOW( ) - INTERVAL 7 DAY,"1","2") AS flg') 6 ) 7 ->orderBy('flg') 8 ->orderBy('updated_at','desc') 9 ->get(); 10

投稿2020/10/14 10:50

whiro

総合スコア31

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

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

guest

0

php

1$model = Model::query() 2 ->whereDate('created_at', '>', now()->subWeek()) 3 ->latest() 4 ->get();

投稿2020/10/14 09:23

編集2020/10/14 09:25
phper.k

総合スコア3923

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

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

chikarawazaman

2020/10/14 09:40

ご回答ありがとうございます。 これだと作成1週間以内のみのリストになりますが、 これで取得したリストの後ろに 対象外のものを再度取得して連結するような実装がよいとのことでしょうか?
phper.k

2020/10/14 10:00

質問からはそのような要件を読み取ることはできませんでした
chikarawazaman

2020/10/14 10:10

質問が悪く申し訳ございませんでした。 要件定義としては、 ・全リストを取得する。 ・更新日順に並べる。 ・作成日から一週間以内をリストの上位に表示する。 です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問