🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

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

Q&A

解決済

3回答

355閲覧

検索で取り出した値を足して表示させたい

rinrin1137

総合スコア87

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

PHP

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

0グッド

0クリップ

投稿2019/10/15 08:56

編集2019/10/15 09:21

実現したいこと

ユーザーが検索画面で表示したい年月を入力検索をし、ヒットしたリストを表示し検索結果の値の合計値を表示したいです。

html

1<form action="list.php" method="POST"> 2 <input type="text" name="search" placeholder="2019/07"> 3 <input type="submit" value="検索"> 4</form>

php

1$search = $_POST['search']; 2$posts = $dsn->query("SELECT * FROM report WHERE date LIKE '%$search%' ORDER BY id DESC"); 3$post = $posts->fetchAll();

検索結果の表示まではできましたが、同時に検索結果の合計値の求め方がわかりません。

ご教授宜しくお願い致します。

現状の検索結果について

データベースのカラムにはid,complete,profitがあり、

id date complete profit


1 2019/01/02 5 10000
2 2019/01/01 2 10000
3 2018/12/31 5 10000

上記のような状態でレコードが日別ごとに格納されております。

検索では該当の日別レコードを全件表示しつつ、complete(当月完了台数)、profit(当月完了利益)の合計値を求めたいです。

該当の日別レコードは表示できている状態ですが、合計値が出せずにいます。

テーブル名はreportとなっております。

2019/01と検索をして、2019/01のみを表示して、completeの合計値を7、profitの合計値を20000にして表示できればと考えております。

再度追記

php

1//当月完了台数、当月完了利益をのTOTALを計算し結果表示 2$sql = "SELECT SUM(complete) as total01, SUM(profit) as total02 FROM report"; 3$res = $dsn->query($sql); 4$i = $res->fetch();

上記だとcomplete、profitのそれぞれのレコード全件の合計値が表示されてしまします・・・。

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

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

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

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

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

yambejp

2019/10/15 09:01

> 検索結果の合計値 とはなんでしょう?
rinrin1137

2019/10/15 09:03

失礼しました。 検索結果とはsearchで検索をした結果の中に、値がございます。
yambejp

2019/10/15 09:04

reportテーブルの状態と、なにを合計するか提示してください
rinrin1137

2019/10/15 09:10

追記させていただきました。 テーブル名はreportとなっております。
yambejp

2019/10/15 09:12 編集

>id complete profit >----- ---------- -------- >1 5 10000 >2 2 10000 というreportテーブルでは、where date like ・・・ の絞り込みができません
rinrin1137

2019/10/15 09:13

失礼しました。 説明文を修正させていただきました。m(_ _)m
guest

回答3

0

php

1<?php 2 3ini_set('display_errors', true); 4error_reporting(E_ALL); 5 6$search = filter_input(INPUT_POST, 'search'); 7 8$sql = "SELECT sum(complete) as complete, sum(profit) as profit FROM report WHERE date LIKE ? GROUP BY YEAR(`date`), MONTH(`date`)"; 9$stmt = $dsn->prepare($sql); 10$stmt->execute(['%' . $search . '%']); 11 12$rows = $stmt->fetchAll(); 13var_dump($rows);

投稿2019/10/15 09:17

編集2019/10/15 09:27
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

rinrin1137

2019/10/15 09:35

ご回答いただきありがとうございます。 参考にして少しイジってみます。m(_ _)m
guest

0

PHP

1//$post_data = $_POST['search']; 2$post_data = "2019/01"; 3$serch = "FROM report WHERE date LIKE '%{$post_data}%'"; 4$posts = $dsn->query("SELECT * {$serch} ORDER BY id DESC"); 5$post1 = $posts->fetchAll(PDO::FETCH_ASSOC); 6 7$posts = $dsn->query("SELECT 8sum(complete) as complete_total, 9sum(profit) as profit_total 10{$serch} ORDER BY id DESC"); 11$post2 = $posts->fetchAll(PDO::FETCH_ASSOC); 12 13echo "<pre>"; 14print_r($post1); 15print_r($post2); 16echo "</pre>";

2回接続していいなら↑

PHP

1//$post_data = $_POST['search']; 2$post_data = "2019/01"; 3$serch = "FROM report WHERE date LIKE '%{$post_data}%'"; 4$posts = $dsn->query("SELECT *, 5(SELECT sum(complete) {$serch}) as complete_total, 6(SELECT sum(profit) {$serch}) as profit_total 7{$serch} ORDER BY id DESC"); 8$post = $posts->fetchAll(PDO::FETCH_ASSOC); 9 10echo "<pre>"; 11print_r($post); 12echo "</pre>";

1回の接続にこだわるなら↑こんな書き方では強引でしょうか…

投稿2019/10/15 11:09

jinba

総合スコア310

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

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

0

ベストアンサー

こんな感じ

  • 元データ

SQL

1create table report (id int primary key,`date` date,complete int,profit int); 2insert into report values 3(1,'2019-01-02',5,10000), 4(2,'2019-01-01',2,10000), 5(3,'2019-01-01',1,100), 6(4,'2019-01-01',3,200), 7(5,'2020-01-03',4,10000);
  • 集計

SQL

1select t1.id,t2.date,t1.complete,t2.profit from ( 2select id,sum(complete) as complete,sum(profit) as profit 3from report 4where date like '%2019-01%' 5group by id 6with rollup 7) as t1 8left join report as t2 using(id)
  • union allするなら

SQL

1select * from( 2select id,date,complete,profit from report where date like '%2019-01%' 3union all select null,null,sum(complete),sum(profit) from report where date like '%2019-01%' 4) as sub

投稿2019/10/15 09:24

編集2019/10/15 09:33
yambejp

総合スコア116681

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

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

yambejp

2019/10/15 09:28

正直合計数だけ取るのにはselectのリストに加えて 別途sumを使ってselectしてunion allするほうが楽ですね
rinrin1137

2019/10/15 09:29

%2019-01%の部分をユーザー自身がinputで指定した値とするにはどのようにしたらよろしいでしょうか?
yambejp

2019/10/15 09:33

> %2019-01%の部分をユーザー自身がinputで指定した値 それはphp側の処理なのでprepareで処理してください
rinrin1137

2019/10/15 09:48

ありがとうございます。 できるか試してみます。m(_ _)m
rinrin1137

2019/10/17 02:54

ありがとうございました。無事に解決いたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問