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

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

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

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

Q&A

解決済

2回答

14735閲覧

SQL WHERE句でBETWEENを含む複数の条件を指定したい

tomaa

総合スコア84

SQL

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

0グッド

0クリップ

投稿2020/04/10 11:59

前提・実現したいこと

SQLを利用したWEBシステムを開発しています。

WHERE句の中で、BETWEENを使用する期間の条件と、もう一つの条件を合わせて利用するために以下のコードで実行しているのですが、ANDの使用方法で(おそらく)エラーが出てしまいます。

SQL

1SELECT data FROM sample WHERE id = 1 AND BETWEEN '2019-11-29' AND '2019-12-29';

どのようにすれば、複数の条件を指定できるのでしょうか?

発生している問題・エラーメッセージ

SyntaxError at /detail/10/ syntax error at or near "'2019-11-29'" LINE 1: ...herinformation WHERE id = 1 AND BETWEEN '2019-11-2...

試したこと

以下のコードで試しましたが、どちらもエラーとなってしまいます。

SQL

1SELECT data FROM sample WHERE id = 1 AND (BETWEEN '2019-11-29' AND '2019-12-29');

SQL

1SELECT data FROM sample WHERE (id = 1) AND (BETWEEN '2019-11-29' AND '2019-12-29');

補足情報(FW/ツールのバージョンなど)

●開発環境

  • Python: 3.7.5
  • Postgresql:12.1
  • psycopg2:2.8.4

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

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

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

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

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

guest

回答2

0

ベストアンサー

XXX Between X and Y という式が成立していません。

SQL

1WHERE id = 1 AND [対象項目] BETWEEN '2019-11-29' AND '2019-12-29';

投稿2020/04/10 12:36

sazi

総合スコア25327

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

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

tomaa

2020/04/10 12:42

ご回答ありがとうございます。教えていただいた内容でエラーが消えて動きました。 基本的なミスでしたすみません。 ありがとうございました。
guest

0

BETWEEN '2019-11-29' AND '2019-12-29' の部分を
data >='2019-11-29' AND date <= '2019-12-29' にすればエラーが解決すると思います(私はこれで解決しました)。
私もSQLにそんなに精通してはおりませんが、BETWEENの手前でカラムを指定していないのもエラー要因になっているのではと思います。
ANDとBETWEENをそれぞれの条件で併用する場合、BETWEEN a AND bの所を、
(カラムn) >= a AND (カラムn) <= b と置き換えるのが良いのかと思います。
※BETWEEN a AND b にするか (カラムn) >= a AND (カラムn) <= b にするかは好みの範囲ですね。
書きやすさ重視ならBETWEEN a AND b、読みやすさ重視なら(カラムn) >= a AND (カラムn) <= b
ですかね。。。

投稿2020/04/10 12:48

編集2020/04/10 12:57
st-access_91s

総合スコア43

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

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

tomaa

2020/04/10 12:53

ご回答ありがとうございます。 こちらの方法も試してみたいと思います。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問