0

このスキーマを使用してテーブルを作成しようとしています:

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"

これは許可の問題でしょうか?問題は何ですか?

4

1 に答える 1

0

わかりました、Pythonスクリプトを使用して実行するのではなく、SQL自体を実行してこれを修正しました。私の場合、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));")
于 2021-04-01T13:03:43.790 に答える