簡體   English   中英

如何在 SqlAlchemy Python3 中使用日期時間進行原始查詢

[英]How to raw query with datetime in SqlAlchemy Python3

所以我試圖根據日期時間字段timeStamp從表messages中查詢,但我不斷收到錯誤消息。 也許我試圖查詢的方式不正確。

def get_test(self, start_date, end_date):
        
        query = 'SELECT * from messages WHERE messages."timeStamp" > {start_date} and messages."timeStamp" < {end_date};'
        res = self.session.execute(query)
        self.session.commit()
        
        return res.fetchall()

當我運行此代碼時,我收到以下錯誤。

sqlalchemy.exc.ProgrammingError: (psycopg2.errors.SyntaxError) syntax error at or near "00"
LINE 1: ... messages WHERE messages."timeStamp" > 2021-06-01 00:00:00 a...

我也嘗試過使用datetime.strptime方法,但這也沒有用。

def get_test(self, start_date, end_date):
        
        query = f'''SELECT * from messages WHERE messages."timeStamp" > {datetime.strptime(start_date, "%Y-%m-%d %H:%M:%S")}   
        and messages."timeStamp" < {datetime.strptime(end_date, "%Y-%m-%d %H:%M:%S")};'''
        res = self.session.execute(query)
        self.session.commit()
        
        return res.fetchall()

我也嘗試使用查詢參數,但這也不起作用。

 def get_test(self, start_date, end_date):
        
        query = f'SELECT * from messages WHERE messages."timeStamp" > %s and messages."timeStamp" < %s;'
        res = self.session.execute(query, (datetime.strptime(start_date, "%Y-%m-%d %H:%M:%S"), 
                                           datetime.strptime(end_date, "%Y-%m-%d %H:%M:%S")))
        self.session.commit()
        
        return res.fetchall()

如果有人可以在這里幫助我,我將不勝感激。

我認為這里發生了幾件事。

我不認為您的 f 字符串正在填充,而 strptime 用於將字符串轉換為日期,而不是相反。

我會這樣寫:

query = f'SELECT * from messages WHERE messages."timeStamp" > {start_date.isoformat()} and messages."timeStamp" < {end_date.isoformat()};'

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM