如何解决尝试运行创建表查询时出现 UndefinedObjectError
我正在尝试使用此架构创建一个表:
CREATE TABLE IF NOT EXISTS tags (id SERIAL,name TEXT,content TEXT,owner_id BIGINT,uses INTEGER DEFAULT (0),location_id BIGINT,created_at TIMESTAMP DEFAULT (Now() at time zone 'utc'),PRIMARY KEY (id));
但是我在尝试创建它时收到此错误:
Could not create tags.
Traceback (most recent call last):
File "/root/AzuriteBot/launcher.py",line 119,in init
created = run(table.create(verbose=not quiet,run_migrations=False))
File "uvloop/loop.pyx",line 1494,in uvloop.loop.Loop.run_until_complete
File "/root/AzuriteBot/cogs/utils/db.py",line 662,in create
await con.execute(sql)
File "/usr/local/lib/python3.9/dist-packages/asyncpg/connection.py",line 297,in execute
return await self._protocol.query(query,timeout)
File "asyncpg/protocol/protocol.pyx",line 336,in query
asyncpg.exceptions.UndefinedobjectError: operator class "gin_trgm_ops" does not exist for access method "gin"
这可能是权限问题吗?有什么问题?
解决方法
好的,我只是通过运行 sql 本身而不是尝试通过 python 脚本来解决这个问题。就我而言,db
是数据库池对象:
await db.fetch("CREATE TABLE IF NOT EXISTS tags (id SERIAL,name TEXT,content TEXT,owner_id BIGINT,uses INTEGER DEFAULT (0),location_id BIGINT,created_at TIMESTAMP DEFAULT (now() at time zone 'utc'),PRIMARY KEY (id));")
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。