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

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

ただいまの
回答率

87.34%

Django クエリのシングルクォーテーションについて

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,247

score 42

したいこと

modelに直接クエリを記載しているのですが、
betweenの日付のシングルクォーテーションがうまくいきません。。

発生している問題

シングルクォーテーションをクエリ内につけると、
シングルクォーテーションが「2つ」ついているSQLが発行され、

じゃあ、変数で代入される日付に最初からシングルクォーテーションがついてるのかな?
と思って、
シングルクォーテーションをクエリ内につけないと
シングルクォーテーションがないSQLが発行されます。。。

(変な日本語ですみません、、、)

該当のソースコード

# Create your models here.
class UserData(models.Model):
    ユーザーコード = models.CharField(max_length=10,primary_key=True)
    氏名 = models.CharField(max_length=20,null=True)
    役職コード = models.CharField(max_length=6,null=True)
    役職名 = models.CharField(max_length=30,null=True)
    更新日時 = models.DateTimeField(blank=True,null=True)

    class Meta:
        managed = False
        default_permissions = []
        db_table = 'UserData'

    def get_data(self, sdate, edate, name, code):
        return UserData.objects.raw(
            " SELECT *  FROM UserData "
            + " WHERE (更新日時 BETWEEN %s AND %s ) "###ここが問題点です
            + " and 氏名 LIKE '%%%s%%' "
            + " and ユーザーコード LIKE '%%%s%%' "
            + " ORDER BY 更新日時 DESC"
        ,[sdate,edate,name,code])
#コンソールで確認したSQL

##Web画面から入力したパラメータ ⇒{'sdate': '2019-10-01', 'edate': '2019-10-20', 'name': '', 'code': ''}
##sdate.edateの中身 ⇒ 2019-10-18 00:00:00 2019-10-20 23:59:59

<RawQuerySet:  SELECT *  FROM UserData 
 WHERE (更新日時 BETWEEN 2019-10-01 00:00:00 AND 2019-10-20 23:59:59 )  
and 氏名 LIKE '%%'  
and ユーザーコード LIKE '%%'  
ORDER BY 更新日時 DESC>


↑このままだと、betweenのsdateとedateにシングルクォーテーションがついてないので
エラーにはなりませんが、データ抽出ができません。。。

試したこと

%sを '%s'にする
⇒''2019-10-01 00:00:00''になり、シングルクォーテーションがダブるのでエラー

%sを "%s"にする
⇒"'2019-10-01 00:00:00'"になりエラー

%sを \"%s\"にする(バックスラッシュ)
⇒''2019-10-01 00:00:00''になりエラー

%sを \%s\にする(バックスラッシュ)
⇒ \'2019-10-01 00:00:00'\になりえエラー

%sを ''%s''にする
⇒''2019-10-01 00:00:00''になりエラー

お願いします

今までストアドしか使っていなかったので、
どなたかこういう直SQLについてわかる方。。。
教えてください。。。。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

0

TO_TIMESTAMP を使っては?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/10/25 15:29

    ありがとうございます。。。
    だめでした。。。
    3つつけると、4つになって発行され、
    2つつけると、3つになって発行されます。。

    1つつけると、2つになり、
    つけないと、0(クォーテーションがない状態)になります。。。

    キャンセル

  • 2019/10/25 15:52

    張り込む日時データをシングルクォートで囲むことはできますか?
    %s の前に % を続けてみるとか?

    それでもダメならお手上げです。

    キャンセル

  • 2019/10/25 16:11

    ありがとうございます!
    一応自己解決することが出来ました!!
    恐らくその方法になったと思います・・・!

    キャンセル

0

viewの方で、変数に直接

    sdate = param['sdate'] + ' 00:00:00'
    sdate = "\'" + sdate + "\'"
    edate = param['edate'] + ' 23:59:59'
    edate = "\'" + edate + "\'"

として、使うことにしました。。。!

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/10/25 16:18

    お力になれず、すみません。

    キャンセル

  • 2019/10/25 16:21

    とんでもないです!!
    沢山回答頂いてとても勉強になりました。。。。!
    また沢山質問すると思うので、その時もぜひご協力宜しくお願いします!

    キャンセル

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

  • ただいまの回答率 87.34%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る