python - Heroku postgresql 运算符不存在
问题描述
我将我的站点部署到运行 postgresql 的 Heroku。之前,我在运行 sqlite 的烧瓶开发环境中使用它。该应用程序在使用计划视图时运行良好,但是当我从 Heroku 访问计划视图时,出现错误。
班级
class Task(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(80), index=True)
description = db.Column(db.String(200), index=True)
priority = db.Column(db.Integer)
is_complete = db.Column(db.Boolean) ####might be trouble
url = db.Column(db.String(200), index=True)
est_dur = db.Column(db.Integer)
time_quad = db.Column(db.Integer)
timestamp = db.Column(db.DateTime, index=True, default=datetime.utcnow)
user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
路线
@bp.route('/schedule')
#@login_required
def schedule():
currentUser = current_user.id
q1 = Task.query.filter_by(time_quad=1).filter_by(user_id=currentUser).filter_by(is_complete=0).all()
q2 = Task.query.filter_by(time_quad=2).filter_by(user_id=currentUser).filter_by(is_complete=0).all()
q3 = Task.query.filter_by(time_quad=3).filter_by(user_id=currentUser).filter_by(is_complete=0).all()
q4 = Task.query.filter_by(time_quad=4).filter_by(user_id=currentUser).filter_by(is_complete=0).all()
taskAll = q1 + q2 + q3 + q4
print("current user" + str(currentUser))
return render_template('schedule.html', taskList = taskAll)
错误
Exception on /schedule [GET]
Traceback (most recent call last):
File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/engine/base.py", line 1193, in _execute_context
context)
File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/engine/default.py", line 509, in do_execute
cursor.execute(statement, parameters)
psycopg2.ProgrammingError: operator does not exist: boolean = integer
LINE 3: ....time_quad = 1 AND task.user_id = 1 AND task.is_complete = 0
HINT: No operator matches the given name and argument type(s). You might need to add explicit type casts.
[SQL: 'SELECT task.id AS task_id, task.name AS task_name, task.description AS task_description, task.priority AS task_priority, task.is_complete AS task_is_complete, task.url AS task_url, task.est_dur AS task_est_dur, task.time_quad AS task_time_quad, task.timestamp AS task_timestamp, task.user_id AS task_user_id \nFROM task \nWHERE task.time_quad = %(time_quad_1)s AND task.user_id = %(user_id_1)s AND task.is_complete = %(is_complete_1)s'] [parameters: {'time_quad_1': 1, 'user_id_1': 1, 'is_complete_1': 0}] (Background on this error at: http://sqlalche.me/e/f405)
解决方案
PostgreSQL 有一个真正的布尔类型,但 SQLite 没有,SQLite 通常使用一和零来表示真假(分别)。当你这样说时:
filter_by(is_complete=0)
将0
被 SQLite 解释为“假”,但被 PostgreSQL 解释为数字零;因此 Heroku 抱怨无法比较中的布尔值和整数task.is_complete = 0
。如果您的意思是“假”,请这样说:
filter_by(is_complete=False)
与 SQLite 交谈时应将其转换为零,与PostgreSQL交谈时应将其转换为正确的布尔值'f'
(或)。false
一旦你解决了这个问题,我强烈建议你在你的开发环境中安装 PostgreSQL,如果那是你要部署的数据库。如果您在同一个堆栈上开发、测试和部署,您将拥有更好的时间。
推荐阅读
- google-cloud-platform - 光束中大窗口的间隔触发
- node.js - 如何使用 pg 从 postgres 存储过程(或函数)中检索结果集
- python - 如何在 Telethon 事件处理程序中获取特定时区的时间
- json - 雪花 VARCHAR 到 VARIANT 插入“\”字符
- json - jackson - 避免序列化 getter
- javascript - 如何从 VS Code 隐藏文件
- python - Odoo,create() 缺少 1 个必需的位置参数:'vals'
- identityserver4 - IdentityServer4 API 调用另一个 API
- amazon-emr - 从 Airflow(使用气流 Livy 运算符)向 Livy(在 EMR 中)提交 Spark 作业
- node.js - sequelize-auto 找不到模块“续集”