1

我正在尝试将一个简单的 Sinatra 应用程序移至 Heroku。使用 Taps 迁移 Ruby 应用程序代码和现有 MySQL 数据库进展顺利,但我收到以下 Postgres 错误:

PostgresError - 错误:运算符不存在:text = integer LINE 1: ...d_at", "post_id" FROM "comments" WHERE ("post_id" IN (4, 17,... ^ 提示:没有运算符匹配给定名称和参数类型。您可能需要添加显式类型转换。

很明显,该问题与查询中的类型不匹配有关,但这是由 DataMapper ORM 以非常高的抽象级别从 Haml 模板发出的,所以我不确定如何控制它...

具体来说,这似乎是p.comments从我的 Haml 模板中调用的,其中p表示给定的帖子。

Datamapper模型相关如下:

class Post
    property :id, Serial
    ...
    has n, :comments
end

class Comment
    property :id, Serial
    ...
    belongs_to :post
end

这在我使用 MySQL 的本地和当前托管环境中运行良好,但 Postgres 显然更严格。

必须有数百个 Datamapper 和 Haml 应用程序在 Postgres DB 上运行,并且这种模型关系是超常规的,所以希望有人已经看到(并确定如何解决)这个问题。谢谢!

更新:请参阅Heroku:从 MySQL 迁移数据库后的 Postgres 类型运算符错误以进行解决。

4

1 回答 1

1

看起来 post_id 的类型是 TEXT 而不是 INTEGER。要解决此问题,您必须更改数据类型。这在 8.3 版中已更改,旧版本具有隐式转换。你可以告诉 PostgreSQL 这样做:

CREATE FUNCTION pg_catalog.text(integer) RETURNS text STRICT IMMUTABLE LANGUAGE SQL AS 'SELECT textin(int4out($1));';
CREATE CAST (integer AS text) WITH FUNCTION pg_catalog.text(integer) AS IMPLICIT;

CREATE FUNCTION pg_catalog.text(smallint) RETURNS text STRICT IMMUTABLE LANGUAGE SQL AS 'SELECT textin(int2out($1));';
CREATE CAST (smallint AS text) WITH FUNCTION pg_catalog.text(smallint) AS IMPLICIT;

CREATE FUNCTION pg_catalog.text(bigint) RETURNS text STRICT IMMUTABLE LANGUAGE SQL AS 'SELECT textin(int8out($1));';
CREATE CAST (bigint AS text) WITH FUNCTION pg_catalog.text(bigint) AS IMPLICIT;

另见http://wiki.postgresql.org/wiki/Image:Pg83-implicit-casts.sql

于 2010-05-31T07:31:54.397 回答