- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近不得不彻底修改一个最初使用 MySQL 的 Django 项目,但为了部署到 Heroku(按照他们在 docs regarding Django deployment 中的建议),我通过以下方法将 MySQL 数据库迁移到 Postgres:
安装的依赖项:pyscopg2
和 py-mysql2pgsql
设置 Postgres 数据库
迁移的数据库:$ py-mysql2pgsql
— 这会创建一个 mysql2pgsql.yml
文件,如下所示:
mysql:
主机名:本地主机
端口:3306
套接字:/tmp/mysql.sock
用户名: foo
密码: 吧
数据库:your_database_name
压缩:假
目的地:
postgres:
主机名:本地主机
端口:5432
用户名: foo
密码: 吧
数据库:your_database_name
通过以下方式传输数据:$ py-mysql2pgsql -v -f mysql2pgsql.yml
喝了很多杯咖啡后,到 Heroku 的部署成功了(在很大程度上,直到我今天发现这个问题),并且当我运行 $ heroku local
时,该应用程序在 Heroku 上按预期工作。但是今天访问前端某个功能时,浏览器出现数据库错误:
DatabaseError at /projects/
syntax error at or near "SEPARATOR"
LINE 1: ...s, sc.name as sport_category, string_agg(au.email SEPARATOR ...
^
Request Method: GET
Request URL: http://0.0.0.0:8989/projects/
Django Version: 1.5.1
Exception Type: DatabaseError
Exception Value:
syntax error at or near "SEPARATOR"
LINE 1: ...s, sc.name as sport_category, string_agg(au.email SEPARATOR ...
我相信相关代码位于名为business.py的文件中:
def getAllProjects(self):
'''
@note: Retrieve all projects
'''
from django.db import connection
cursor = connection.cursor()
cursor.execute("select p.id, p.title, p.description, p.deadline, pt.name as project_type, s.name as status, sc.name as sport_category, group_concat(au.email SEPARATOR '\n') as project_managers from project p left join project_manager_in_project pmip on p.id = pmip.project_id left join auth_user au on pmip.project_manager_id = au.id inner join project_type pt on p.projectType_id = pt.id inner join status s on p.status_id = s.id inner join sport_category sc on p.sportCategory_id = sc.id where p.deleted = 0 group by p.id")
projects = cursor.fetchall()
return projects
我知道一些讨论类似问题的帖子:
Postgresql - concat_ws like function?
Postgresql GROUP_CONCAT equivalent?
这导致我尝试将 group_concat(au.email SEPARATOR '\n')
更改为 string_agg(au.email SEPARATOR '\n')
,然后 array_agg(au.email SEPARATOR '\n')
但我仍然收到相同的错误。
是否有另一种方法可以解决这个问题并调整此函数以实现解决方法?
更新:对于任何感兴趣的人,下面“考虑我”提供的选定答案(和评论)使我得到了以下更改后的查询语句,到目前为止该语句没有任何问题:
cursor.execute("select \"project\".\"id\", project.title, project.description, \"project\".\"deadline\", \"pt\".\"name\" as \"project_type\", \"sc\".\"name\" as status, \"sc\".\"name\" as sport_category, string_agg(au.email, E'\n') as project_managers from project left join project_manager_in_project pmip on project.id = pmip.project_id left join auth_user au on pmip.project_manager_id = au.id inner join project_type pt on project.\"projectType_id\" = pt.id inner join status s on project.\"status_id\" = \"s\".id inner join sport_category sc on \"project\".\"sportCategory_id\" = \"sc\".\"id\" where project.deleted = 0 group by 1,2,3,4,5,6,7")
由于该应用程序的原始开发人员创建了所有带有双引号的表格,这导致了列 p.projecttype_id 不存在
错误以及其他类似的不存在
当我所做的一切被删除SEPARATOR
并将group_concat
(两者都不存在于Postgres中)更改为string_agg
时,我不断收到错误。换句话说,根据“考虑我”的建议,我必须用双引号封装几乎所有的表和列名称(当然还要转义引号)。
最佳答案
正如您已经看到的,您需要将 GROUP_CONCAT()
替换为 STRING_AGG()
。在 GROUP BY
子句中包含聚合函数内未使用的每一列。
select
p.id,
p.title,
p.description,
p.deadline,
pt.name as project_type,
s.name as status,
sc.name as sport_category,
string_agg(au.email, E'\n') as project_managers
from
project p
left join project_manager_in_project pmip on p.id = pmip.project_id
left join auth_user au on pmip.project_manager_id = au.id
inner join project_type pt on p.projectType_id = pt.id
inner join status s on p.status_id = s.id
inner join sport_category sc on p.sportCategory_id = sc.id
where
p.deleted = 0
group by 1,2,3,4,5,6,7
Postgres 中没有 SEPARATOR
关键字(至少我不知道它的存在)。
关于python - 从 MySQL 迁移到 Postgres 后了解 "SEPARATOR"处或附近的语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36165609/
我的子查询给出了一个错误:Msg 102, Level 15, State 1, Line 17 Incorrect syntax near ')'. SELECT SalesArea, Branch
当我尝试运行此查询时: select branch_no, max (avg_salary) from (select allocatedto, avg (salary) from sta
所以我正在更新 phpmyadmin 中的表。数据在里面,列已成功创建。当我尝试使用下面的代码添加图像时,出现此错误 Unexpected character. (near "\" at positi
我正在尝试在 phpMyAdmin 中执行以下查询,但出现错误。我已经查看过类似的问题,但我仍然无法弄清楚为什么它不起作用。 INSERT INTO discussion_forum (event_t
我正在用 C 构建一个 client-server socket 模拟 我接受来自客户端的 TCP 连接 然后客户端发送消息到我的服务器。我已成功收到消息,然后遍历 structs 的 array 以
我在 AUTOINCREMENT 附近遇到语法错误。这个错误的原因是什么? CREATE TABLE person ( id INTEGER NOT NULL AUTOINCREMENT,
当我尝试使用 java 在 SQLite 中以编程方式创建数据库时,它会在控制台中生成以下错误。 java.sql.SQLException: near "DATABASE": syntax erro
我似乎无法弄清楚出了什么问题。我尝试查询的子部分,但仍然无法解决问题。 表格格式: poi(id int, minX float, minY float, maxX float, maxY float
我在VHDL中编写了以下代码: library IEEE ; use IEEE.STD_LOGIC_1164.all ; entity encoder is port( x : in std_
我在我的游戏服务器中使用这些文件,每次我添加一个新的玩家模型时,我都会得到 [ERROR] lua/autorun/server/fastdlskins.lua:938: '' expected ne
我正在尝试更新我的 sqlite3 数据库,但出现此错误。我能够成功地将数据插入同一数据库,但无法更新它。请帮忙。 [SQLITE_ERROR] SQL error or missing databa
我想在通知区域旁边显示一个小弹出窗口。它类似于 Outlook/Skype/Live! Messenger/etc 在显示有关新消息的通知时会执行此操作。在我的例子中,它将有一些输入控件(文本框、日期
我正在尝试编写简单的程序以使用 gorp 将行插入表中,但在创建表时出现错误。 代码如下: package main import _ "github.com/mattn/go-sqlite3" im
我正在尝试运行工作目录中的 Octave 文件,但出现错误。 Octave 似乎没有认识到它应该运行该文件。 unknown@unknown> dir .
我正在尝试编写一些代码来模拟具有两个三态缓冲器和VHDL中的上拉电阻的电路。下面是我的代码: library ieee; use ieee.std_logic_1164.all; entity Pul
你能好心告诉我这里出了什么问题吗? conn 是 DriverManager.getConnection(DB_URL) try { PreparedState
我想在go中创建一个事务,同时这样做会出现错误:near "SET": syntax error。代码: db.Exec("SET TRANSACTION ISOLATION LEVEL REPEAT
所以我想用这样的颜色可视化一个矩阵 library(RColorBrewer) vec = rbinom(10000,1,0.1) n = sum(vec) vec = ifelse(vec == 1
private static final String QUERY = "SELECT * FROM " + TABLE_SONG_DETAILS + " WHERE " + TABLE_SONG_D
希望大家一切都好。 我正在尝试创建一个 mysql 触发器,但是我不断收到以下错误: [Err] 1064 - You have an error in your SQL syntax; check
我是一名优秀的程序员,十分优秀!