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

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

詳細はこちら
MySQL

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

Q&A

解決済

1回答

750閲覧

複数テーブルから条件を満たすものを出力

nkt070408

総合スコア29

MySQL

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

0グッド

1クリップ

投稿2019/11/20 07:33

編集2019/11/20 07:49

MySQLを使ってアプリのインストール日時を取得し、
インストール日から数えて3日以内に3度以上ログインに成功したユーザのみを
出力するという課題で詰まっています。

timestampをbetweenで期間を指定してそれをcount()することでできないか試してみましたが
うまくいきませんでした。
count(timestamp between date_format(timestamp ,'%Y%m%d%h%m')
and date_format(timestamp + INTERVAL 3 DAY,'%Y%m%d%h%m')) > 3

インストールテーブルとログインテーブルのそれぞれのデータから
課題文の期間を指定するにはどうしたらいいでしょうか。

<install> id,timestamp 20008,2019/10/19 10:45 ... <login> id,timestamp 20008,2019/10/20 9:10 20008,2019/10/20 11:20 20008,2019/10/20 12:10 20008,2019/10/20 14:20 ...

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

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

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

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

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

m.ts10806

2019/11/20 07:36

インストール日時?なんのインストールですか?
m.ts10806

2019/11/20 07:37

ひとまず自身の書いたコードをご提示ください。 また、対象テーブルのCREATE文とサンプルデータのINSERT文もご提示ください
退会済みユーザー

退会済みユーザー

2019/11/20 07:44 編集

loginテーブルのカラム名が提示されていません。
退会済みユーザー

退会済みユーザー

2019/11/20 07:45

日付周りの関数を利用できるかどうかの判断ができないので、テーブル定義をCREATE文で提示してください。
yambejp

2019/11/20 07:46

「3日以内」は日時、日付? 日時:2019/10/19 10:45:00 ~2019/10/22 10:44:59 日付:2019/10/19~2019/10/22
nkt070408

2019/11/20 07:48

3日以内というのは日付です。
guest

回答1

0

ベストアンサー

例えばこう

SQL

1create table install(id int primary key,timestamp timestamp); 2insert into install values 3(20008,'2019/10/19 10:45'), 4(20009,'2019/10/19 00:00'); 5 6create table login(id int primary key auto_increment,uid int,timestamp timestamp); 7insert into login(uid,timestamp) values 8(20008,'2019/10/20 9:10'), 9(20008,'2019/10/20 11:20'), 10(20008,'2019/10/20 12:10'), 11(20008,'2019/10/20 14:20'), 12(20009,'2019/10/20 00:00'), 13(20009,'2019/11/20 00:00'), 14(20009,'2019/11/20 01:00'), 15(20009,'2019/11/20 02:00');

上記id=20008は4回あるが、id=20009は1回しか無い

SQL

1select uid,sum((select timestamp from install where id=login.uid) between date(timestamp) - interval 2 day and date(timestamp)) as count 2from login 3group by uid;

条件:3回以上を抜き出すので

SQL

1select uid 2from login 3group by uid 4having sum((select timestamp from install where id=login.uid) between date(timestamp) - interval 2 day and date(timestamp))>=3

投稿2019/11/20 08:01

yambejp

総合スコア116683

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

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

nkt070408

2019/11/20 08:20

提示していただいたやり方を参考に条件を満たすコードを 作成することができました。 ご回答ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問