Postgresql运算符类“varchar_pattern_ops”不接受数据类型整数

Postgresql运算符类“varchar_pattern_ops”不接受数据类型整数,第1张

概述我正在尝试将我的数据id postgresql从字符串迁移到 django中的整数,以便在sphinx搜索中使用它们.首先,我正在进行数据迁移,将数据转换为字符串整数 db.execute('''UPDATE the_table SET foo='1' WHERE foo='bar';''') 然后我正在进行架构迁移 ALTER TABLE the_table ALTER COLUMN col_n 我正在尝试将我的数据ID postgresql从字符串迁移到 django中的整数,以便在sphinx搜索中使用它们.首先,我正在进行数据迁移,将数据转换为字符串整数
db.execute('''UPDATE the_table SET foo='1' WHERE foo='bar';''')

然后我正在进行架构迁移

ALTER table the_table ALTER ColUMN col_name TYPE integer USING (col_name::integer);

喜欢它被告知here

但是我收到了一个错误

ERROR: operator class “varchar_pattern_ops” does not accept data type integer

sql-состояние: 42804

South和pgadmin都会发生此错误.数据是正确的 – 字符串类型为Null或整数.我究竟做错了什么?

我只能像这样重现你的错误信息:
denis=# create index test_IDx on test (val varchar_pattern_ops);CREATE INDEXdenis=# alter table test alter val type int using (val::int);ERROR:  operator class "varchar_pattern_ops" does not accept data type integer

如果你有一个像这样的时髦索引,请尝试删除并重新创建它:

denis=# drop index test_IDx;DROP INDEXdenis=# create index test_IDx on test (val);CREATE INDEXdenis=# alter table test alter val type int using (val::int);ALTER table

相关文档:

http://www.postgresql.org/docs/current/static/indexes-opclass.html

总结

以上是内存溢出为你收集整理的Postgresql运算符类“varchar_pattern_ops”不接受数据类型整数全部内容,希望文章能够帮你解决Postgresql运算符类“varchar_pattern_ops”不接受数据类型整数所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1181362.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存