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

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

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

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

Q&A

解決済

1回答

1211閲覧

phpで連想配列内のから複数条件に合致する値を抽出する方法

singlestroke

総合スコア68

PHP

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

0グッド

0クリップ

投稿2017/10/08 01:05

###やりたいこと

DBから呼び出して連想配列にしたスケジュールのデータ内から、ユーザー別に直近1週間のデータを抽出したい。

現状ある配列
$user_ids(ユーザーidを格納する配列)
Array
(
[0] => 1
[1] => 2
)

$dates(直近1週間の日付を格納する配列)
Array
(
[0] => 2017-10-08
[1] => 2017-10-09
[2] => 2017-10-10
[3] => 2017-10-11
[4] => 2017-10-12
[5] => 2017-10-13
[6] => 2017-10-14
)

$rows(スケジュールのDBから呼び出したデータを格納する配列)
Array
(
[0] => Array
(
[user_id] => 1
[date] => 2017-10-12
[time1] => 1
[time2] => 0
[time3] => 0
)

[1] => Array ( [user_id] => 1 [date] => 2017-10-13 [time1] => 1 [time2] => 1 [time3] => 0 ) [2] => Array ( [user_id] => 1 [date] => 2017-10-14 [time1] => 1 [time2] => 1 [time3] => 1 ) [3] => Array ( [user_id] => 2 [date] => 2017-10-12 [time1] => 1 [time2] => 0 [time3] => 0 ) [4] => Array ( [user_id] => 2 [date] => 2017-10-10 [time1] => 1 [time2] => 1 [time3] => 0 ) [5] => Array ( [user_id] => 2 [date] => 2017-10-09 [time1] => 1 [time2] => 1 [time3] => 1 )

)

実現できたコード

lang

1 // ユーザーごとに1行でスケジュール表示 2 foreach ($user_ids as $u) { 3 $html .= "<tr>\n"; 4 $html .= "<th>" . $u . "</th>\n"; 5 6 // 直近7日分の日付を表示 7 foreach ($dates as $d) { 8 $html .= "<td>"; 9 // 日付を確認用に表示 10 $html .= "<!--" . $d . "-->"; 11 12 // 全スケジュールデータをforeachでまわす 13 foreach ($rows as $key => $row) { 14 // ユーザーID及び日付が一致したら 15 if (intval($row['user_id']) === $u && $row['date'] === $d) { 16 $html .= $row['timezone1']; 17 $html .= $row['timezone2']; 18 $html .= $row['timezone3']; 19 } 20 } 21 $html .= "</td>\n"; 22 } 23 $html .= "</tr>\n"; 24 }

###いただきたい回答
1.配列関連の関数でもっと簡単に記述することは可能でしょうか。
2.また、同一ユーザーで同一の日付でデータがあった場合に複数あることを認識するためにはどのようにしたらよいのでしょうか。

よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

最終的に取得したい内容が理解しきれていないかもしれず、
コード上の解決策ではないのでご質問の意図とは違う回答かもしれません。

目的の操作はPHPで行うより、ユーザー毎に絞ったSQLを発行する対応がよいのではないかと思います。
使用されているデータベースが不明でしたので、日付等は固定値で指定していますが、下記のようなイメージです。

sql

1SELECT user_id, date, time1, time2, time3 FROM schedules 2WHERE user_id = :user_id 3 AND date BETWEEN '2017-10-08' AND '2017-10-14';

同じ日付のレコードがいくつあるかは下記のような形で取得可能かと思います。

sql

1SELECT user_id, date, COUNT(date) FROM schedules 2WHERE user_id = :user_id 3 AND date BETWEEN '2017-10-08' AND '2017-10-14' 4GROUP BY user_id, date;

投稿2017/10/08 02:37

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

singlestroke

2017/10/11 22:43

ご提案いただきました方針でなんとか解決できました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問