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

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

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

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

SQL

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

Q&A

解決済

2回答

5604閲覧

日ごとで最小/最大の値を抽出したい

WaterSausage

総合スコア3

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

SQL

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

0グッド

0クリップ

投稿2020/10/22 12:25

前提・実現したいこと

タイトルでは最小/最大と記載しましたが、
まずは最小値を抽出することを焦点にご相談したいと思います。

次のようなユーザーアクセスログがあり、
"日ごと"で、”そのユーザーが”一番最初にアクセスした時間を抽出したいです。

ソース元[AccessLog]

DateName
2020/10/1 7:00Taro
2020/10/1 8:30Taro
2020/10/1 13:00Taro
2020/10/2 8:00Taro
2020/10/2 9:30Taro
2020/10/1 7:30Hanako
2020/10/2 9:00Hanako
2020/10/2 10:00Hanako

抽出したいデータ

DateName
2020/10/1 7:00Taro
2020/10/2 8:00Taro
2020/10/1 7:30Hanako
2020/10/2 9:00Hanako

試したこと

ソース元のテーブルから算出すると難しかったので、
あらかじめ1日分のデータを抽出したテーブルを用意し、
1日分の最小値を出すことはできました。

しかしながら、ログ集計が1週間や1ヶ月分ともなると現実的でなくつまづいています。
複数の条件を組み合わせることに慣れていなく、お力添えいただけますと幸いです。

1日分のアクセスログ[1day_AccessLog]

DateName
2020/10/1 7:00Taro
2020/10/1 8:30Taro
2020/10/1 13:00Taro
2020/10/1 7:30Hanako

SQL

1SELECT Date,Name 2 FROM ( 3 SELECT 4 Date, 5 Name, 6 ROW_NUMBER() OVER(PARTITION BY Name ORDER BY Date ASC) AS MinDate 7 FROM 1day_AccessLog 8 ) TEMP 9WHERE MinDate = 1

抽出データ

DateName
2020/10/1 7:00Taro
2020/10/1 7:30Hanako

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

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

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

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

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

guest

回答2

0

正直そういう集計が前提であればテーブル構造を日付と時間で分けたほうが効率的で処理も速いと思います

投稿2020/10/23 01:37

yambejp

総合スコア114915

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

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

WaterSausage

2020/10/23 14:10

ご回答ありがとうございます。 確かに別テーブルを用意することも考えていました。 ただそこからどう抽出するのかいまいちわかっておりませんでした。 効率のことも考えて別案も検討してみます。 ありがとうございました。
guest

0

ベストアンサー

あまり難しく考えなくて良いかと思います。

SQL

1select min(date) as date, name 2from access_log 3group by cast(date as date), name

投稿2020/10/22 15:10

sazi

総合スコア25206

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

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

WaterSausage

2020/10/23 14:09

ご回答ありがとうございます。 SQL初心者で手探りでやっておりました。 すごくシンプルな回答でスッキリしました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問